首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

python学习3-内置数据结构3-字符

字符串是集合类型 1、定义 s = 'hello python' s = "hellp python" 以上2种没有区别 s = '''hello python''' s = """hello python""" 以上2种没有区别 区别在于三引号可以定义多行字符串 2、转义和自然字符串 s = 'i like \npython' 避免转义用r前缀 path = r'c:\nt\ 3、查 s[index] #返回字符串 4、字符串不可改变,可迭代 5、连接 “分隔符”.join(lst) #join是连接字符串方法,参数是可迭代对象, 6、分隔 s.split(‘分隔符’[,maxsplit=-1]) #默认使用空格分隔,多个当一个处理;当指定空格时,按每个空格分隔;maxsplit表示分隔几次,默认为-1,表示分隔所有 s.rsplit是split从右往左分隔,当不使用maxsplit时,两者一致,但是从左往右效率更高。 s.splitlines() #按行分隔,如果参数为True,则带换行符 s.partition('分隔符') #总是分成三部分,头、参数和尾部。适合分隔路径。 s.rpartition('分隔符') #和partition类似,从左往右分隔 7、转化 s,upper() #所有字母变为大写 s.lower() #所有字母变为小写 s.title() #所有首字母大写 s.capitalize() #仅第一个单词首字母大写 s.casefold() #不同平台有不同表现形式,同一平台下相同,通常用于忽略大小写的比较 s.swapcase() #大小写互换 8、显示 s.zfill(width) #不足width长度时,在前面加0补满 s.expandtabs(count) #把tab转为为count个空格 9、修改 s.replace(old,new[,count]) #替换,默认全部替换 s.strip([‘字符’]) #移除前后的指定字符,默认为移除空白 s.lstip(['字符 #只移除左边的指定字符 s.rstrip(['字符']) #只移除右边的指定字符 s.ljust(width[,'填充符']) #在左边填充,默认为空格 s.center(width[,'填充符']) #在多少字符中居中显示,其他用填充符,默认为空格 s.rjust(width[,'填充符']) #在右边边填充,默认为空格 10、查找 s.find('字符'[,start.end]) #从左往右查找,返回找到字符串的首字母的索引,当不存在时返回-1 s.rfind('字符'[,start,end]) #从右往左查找,都是先用start和end截取之后再查找 s.index('字符'[,start,end]) #和find一样,唯一区别是查找不到返回value error。 s.rindex('字符'[,start,end]) #从右往左查找 s.count('字符'[,start,end]) #查找字符出现的次数 list(enumerate(s)) 返回索引和值 11、判断 s.startswith('字符'[start,end]) #判断是否以字符为首字母开始,start表示从此位置开始比较 s.endswith('字符'[start,end]) #判断是否以字符结尾 s.isalnum() #判断是否只包含字母和数字 s.isidentifier() #判断是否是合法标识符:字母或者下划线开头;仅包含字母和下划线 12、字符串格式化 是拼接字符串的一种手段 2.6之前:用类似printf,继承c语音而来 'i love %s, i am %d' % ('python'.18) #如果类型不匹配,会typeerror %s 字符串 %d 整型 %f 浮点型 2.6开始format方法:用{}做占位符,可以在大括号中加位置,可以重复使用如,也可以加标识符: 'i love {0} , you love {0} , i am {age} you name {name}'.format('python',age=12,name='tom') 当占位符和参数不匹配时会报错

01

python format函数

在Python 3.0中,%操作符通过一个更强的格式化方法format()进行了增强。对str.format()的支持已经被反向移植到了Python 2.6 在2.6中,8-bit字符串和Unicode字符串都有一个format()方法,这个方法会把字符串当作一个模版,通过传入的参数进行格式化。这个用来格式化的模版使用大括号({,})作为特殊字符。 # Substitute positional argument 0 into the string. "User ID: {0}".format("root") -> "User ID: root" # Use the named keyword arguments  'User ID: {uid} Last seen: {last_login}'.format(   uid='root',   last_login = '5 Mar 2008 07:20') ->  'User ID: root Last seen: 5 Mar 2008 07:20' 大括号可以写两遍来转义。 format("Empty dict: {{}}") -> "Empty dict: {}" 字段名字可以为整数,表示参数的位置。像{0}, {1}等。也可以是参数的名字。你以可以使用字段的组合来读取属性或者字典的key值。 import sys 'Platform: {0.platform}\nPython version: {0.version}'.format(sys) ->  'Platform: darwin\n  Python version: 2.6a1+ (trunk:61261M, Mar 5 2008, 20:29:41) \n  [GCC 4.0.1 (Apple Computer, Inc. build 5367)]' import mimetypes  'Content-type: {0[.mp4]}'.format(mimetypes.types_map) ->  'Content-type: video/mp4' 注意,当使用字典类型的表示方法,如[.mp4]时,你不需要引号将字符串(.mp4)引起来;它会查找用.mp4作为主键的值。以整数开头的字符串会被转换成一个整数。你不能在被格式化的字符串中写复杂的表达式。 到此,我们已经演示了怎样替换指定的字段。我们还可以通过在格式化指示符后面添加一个冒号来进行精确格式化。例如: # Field 0: left justify, pad to 15 characters # Field 1: right justify, pad to 6 characters fmt = '{0:15} ${1:>6}' fmt.format('Registration', 35) ->  'Registration $ 35' fmt.format('Tutorial', 50) ->  'Tutorial $ 50' fmt.format('Banquet', 125) ->  'Banquet $ 125' 格式化指示符可以通过嵌套进行引用。 fmt = '{0:{1}}' width = 15 fmt.format('Invoice #1234', width) ->  'Invoice #1234 ' width = 35 fmt.format('Invoice #1234', width) ->  'Invoice #1234 ' 可以指定所需长度的字符串的对齐方式。 效果字符: < (默认)左对齐 > 右对齐 ^ 中间对齐 = (只用于数字)在小数点后进行补齐 格式化指示符可以包含一个展示类型来控制格式。例如,浮点数可以被格式化为一般格式或用幂来表示。 >>> '{0:g}'.format(3.75)  '3.75' >>> '{0:e}'.format(3.75)  '3.750000e+00' 展示类型有很多。2.6的文档里有完整的列表。这里列出一些示例。 'b' - 二进制。将数字以2为基数进行输出。 'c' - 字符。在打印之前将整数转换成对应的Unicode字符串。 'd' - 十进制整数。将数字以10为基数进行输出。 'o' - 八进制。将数字以8为基数进行输出。 'x' - 十六进制。将数字以16为基数进行输出,9以上的位数用小写字母。 'e' - 幂符号。用科学计数法打印数字。用'e'表示幂。 'g' - 一般格式。将数值以fixed-point格式输出。当数值特别大的时候,用幂形式打印。 'n' - 数字。当值为整数时和'd'相同,值为浮点数时和'g'相同。不同的是它会根据区域设置插入数字分隔符。 '%' - 百分数。将数值乘以100然后以fixed-point

02

Python每日一谈|No.22.实例.3-Life.1-每日一句名人名言+天气预报

简介:绘文字(日语:絵文字/えもじemoji)是日本在无线通信中所使用的视觉情感符号,绘指图画,文字指的则是字符,可用来代表多种表情,如笑脸表示笑、蛋糕表示食物等。在NTTDoCoMo的i-mode系统电话系统中,绘文字的尺寸是12x12像素,在传送时,一个图形有2个字节。Unicode编码为E63E到E757,而在Shift-JIS编码则是从F89F到F9FC。基本的绘文字共有176个符号,在C-HTML4.0的编程语言中,则另增添了76个情感符号。最早由栗田穰崇(Shigetaka Kurita)创作,并在日本网络及手机用户中流行。自苹果公司发布的iOS 5输入法中加入了emoji后,这种表情符号开始席卷全球,目前emoji已被大多数现代计算机系统所兼容的Unicode编码采纳,普遍应用于各种手机短信和社交网络中。

03
领券