字符串运算符
#重复输出字符串
a='wmmr'
print(a*2)
#成员运算符:如果字符串中(不)包含给定字符返回True(False)
print('w' in a)
#截取字符串中的一部分
print(a[0:2])
#原始字符串,在字符串前加r/R
print(R'wmmr')
'''
%c 转换成字符
%r 优先用repr()函数进行字符串转换
%s 优先用str()函数进行字符串转换
%d/%i 转成有符号十进制数
%u 转成无符号十进制数
%o 转成无符号八进制数
%x/X 转成无符号十六进制数(x/X代表转换后的十六禁止字符的大小写)
%e/%E 转成科学计数法(e/E控制输出e/E)
%f/%F 转成浮点数(小数部分自然截断)
%% 输出%
'''
string="Hello\tWill\n"
print("%s"%string)
print("%r"%string)
'''
* 定义宽度或者小数点精度
- 用做左对齐
+ 在正数前面显示加号
# 在八进制数前面显示零,在十六进制前面显示"0x"或者"0X"
0 显示的数字前面填充"0"而不是默认的空格
(Var) 映射变量(通常用来处理字段类型的参数)
m.n m是显示的最小总宽度,n是小数点后的位数
'''
#字符串函数
#str.capitalize() 将字符串的第一个字母变成大写,其他字母变成小写
string="Ma is an Idiot"
print(string.capitalize())
#str.count(sub,start=0,end=len(str))返回sub在str中出现的次数,start,end为指定范围
str="aabbcabcdeaacaac"
print(str.count('a',0,10))
#str.endswith(suffix,start=0,end=len(str)) 若str或其切片以suffix结尾,返回True,否则返回False
print(str.endswith('c'))
#str.startswith(suffix,start=0,end=len(str)) 若str或其切片以suffix开头,返回True,否则返回False
#str.expandtabs(tabsize=8) 将str中的tab符号转为空格,空格数默认为8
print('aaa\tbbb'.expandtabs(1))
#str.find(sub,start=0,end=len(str)) 检查sub是否在指定范围内,若在则返回开始的索引值,否则返回-1
#str.rfindsub,start=0,end=len(str)) 类似于str.find ,但从右查找
print(str.find('ab'))
#str.index(sub,start=0,end=len(str)) 与find相似,sub不在时返回一个异常
#str.rindex(sub,start=0,end=len(str)) 与str.index类似,从右查找
#str.title() 使字符串标题化,即所有单词首字母大写,其余为小写
#str.swapcase() 翻转字符串字符的大小写
#str.upper() 将字符串的小写字符转为大写
#str.isalnum() 检测字符串是否由字母和数字组成。
s=''
print(s.isalnum())
print(str.isalnum())
print(string.isalnum())
#str.isalpha() 检测字符串是否由字母组成。
#str.isdigit() 检测字符串是否由数字组成。
#str.islower() 检测字符串是否包含区分大小写的字符,并且全是小写
#str.isupper() 检测字符串是否包含区分大小写的字符,并且全是大写
#str.isspace() 检测字符串是否只包含空格
#str.istitle() 检测字符串中所有的单词拼写首字母是否为大写
#str.join(sq) sq是一个字符串序列,以str为分割符连接sq
s='-'
sq=('a','b','c','d')
join=s.join(sq)
print(join)
#str.center(x) 返回一个原字符串居中,并使用空格填充至长度x的新字符串
print(string.center(30))
#str.ljust(w) 使字符串左对齐,并以w格空格填充,如果指定的长度小于字符串的长度则返回原字符串。
#str.rjust(w) 使字符串右对齐,并以w格空格填充,如果指定的长度小于字符串的长度则返回原字符串。
test='abcd'
print(test.rjust(10))
#str.zfill(width) 返回长度为width的字符串,原字符串右对齐,前面填充0
#str.split(s="", num=string.count(s))
#str.lstrip() 截断字符串左边的空格
#str.rstrip() 截断字符串右边的空格
test=' abc'
print(test.lstrip())
#str.strip(s) 用于移除首尾指定字符,s为空则移除空格
test=' abc '
print(test.strip())
test='123333321'
print(test.strip('12'))
#s为分割符默认为所有的空字符,包括空格、换行(\n)、制表符(\t)等。num为分割次数。
str = "Line1-abcdef \nLine2-abc \nLine4-abcd"
print(str.split())#以空格,换行符为分割符
print(str.split(' ',1))#以空格为分割符,只分割一次
#str.partition(s),以s作为分割符,返回三元组:左子串,分割符,右子串
print('abcdefg'.partition('d'))
#str.rpartition(s) 与partition类似,但是是从右边查找
print('abcdefg'.rpartition('d'))
#str.splitlines([keepends]) 按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,
#如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。
print('abc\n\ndef\ng'.splitlines(True))
print('abc\n\ndef\ng'.splitlines(False))
#max(str) 返回str中最大的字母
#min(str) 返回str中最小的字母
test='abcdef'
print(max(test))
print(min(test))
#str.replace(s1,s2,num=str.count(s1)) 用s2替换s1,替换次数默认不超过s1在str中出现的次数
#maketrans(intab,outtab) 用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,
# 第一个参数是字符串,表示需要转换的字符,第二个参数是字符串表示转换的目标,两参数长度需一致
intab = b"aeiou"
outtab = b"12345"
trantab = bytes.maketrans(intab, outtab)
str = b"this is string example....wow!!!"
print(str.translate(trantab))
#一次替换多组字符
intab='aeiou'
outtab='12345'
str="this is string example....wow!!!"
print(str.translate(dict((ord(x), y) for (x, y) in zip(intab, outtab))))
print("%d to hex is %x"%(100,100))
students = [{"name":"Wilber", "age":27},
{"name":"Will", "age":28},
{"name":"June", "age":27}]
print("name: %10s,age: %10d"%(students[0]["name"],students[0]["age"]))
print("name: %-10s,age: %-10d"%(students[1]["name"],students[1]["age"]))
print("name: %*s,age: %*d"%(10,students[2]["name"],10,students[2]["age"]))
for student in students:
print("%(name)s is %(age)d years old"%student)