3、python数据类型之字符串(str)
字符串是任何计算机语言中最常见的数据类型,python中也不例外,因此熟练掌握字符串是学习python的必备技能。
python中字符串三种定义方式
str = 'wang' str = "wang" str = """wang"""
字符串所有方法如下:
['capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
字符串常见的操作,需要熟练掌握
1、按照索引取值,正向取、反向取
2、切片(切片操作顾头不顾尾,可以按照步长进行切片)
3、长度len (str)
4、成员运算 in not in
5、移除空白strip
6、切分split
7、循环
1、按照索引取值,正向取、反向取(索引每次只能取一个元素)
str1 = 'wang' #正向取出索引为1的字符 print(str1[1]) #反向取出索引为-1的字符,即最后一个字符 print(str1[-1])
2、切片(切片操作顾头不顾尾,可以按照步长进行切片)可以取多个元素
str2='wangchengliang' #正向取切片取出出索引为0到1的字符,[0:2]不含2 print(str2[0:2])
3、长度len (str3)
str3='wang' #len(str3)获取str3的长度 print(len(str3))
4、成员运算 in not in
str4 = 'wangw' #判断'wa','q'是否是str4的成员 print('wa'in str4) print('q' not in str4)
5、移除空格strip,lstrip去掉左边空格, rstrip去掉右边空格
#将字符串两端空格移除,返回字符串'wang5' str5=' wang5 ' print(str5.strip()) #将字符串两端'#'移除,返回字符串'wang5' str5_1='##wang5##' print(str5_1.strip('#'))
6、切分split
str6="12343242354361254368634" #以2位切割符,切割字符串str2,并返回一个列表 print(str6.split('2')) name='root:x:0:0::/root:/bin/bash' #默认分隔符为空格 print(name.split(':')) name='C:/a/b/c/d.txt' #只想拿到顶级目录 print(name.split('/',1))
7、循环
str7='wang' for i in str7: print(i)
常见方法
strip lstrip rstrip
lower upper
startswith endswiht
format 三种玩法
split rsplit
replace
isdigit
capitalize
将字符串首字母变成大写
name = 'my \tname is wanganchengliang' print(name.capitalize())
count
统计字符串中某个字符出现的次数或某个子字符串出现的次数
name = 'my \tname is wanganchengliang' print(name.count('an'))
center
打印50个字符,不够50个,用-补充,并把字符串放在中间
name = 'my \tname is wanganchengliang' print(name.center(50,"-"))
encode
把字符串转换成二进制
name = 'my \tname is wanganchengliang' print(name.encode())
endswith
判断字符串以什么结尾
name = 'my \tname is wanganchengliang' print(name.endswith("ng")) str1 = '#swangchengliang' #判断是否以'#'开头 print(str1.startswith('#'))
expandtabs
将字符串中已有的空格扩大多少倍
name = 'my \tname is wanganchengliang' print(name.expandtabs(tabsize=20))
find
返回字符串中子符或子字符串的索引位置
name = 'my \tname is wanganchengliang' print(name.find("name"))
format
格式化字符串输出
name1="my name is {name} and I am {years} old" print(name1.format(name='wang',years=22))
format_map
字典方式格式化字符串输出
print(name1.format_map({'name':'wang','years':22}))
isalnum
确认字符串中是纯英文字符,真返回True
print("123abc".isalnum())
isalpha
确认字符串中是否包含阿拉伯数字和字符,真返回True
print("abc".isalpha())
isdecimal
是否是十进制
print("123".isdecimal())
isdigit
是否是一个整数
print("123".isdigit())
isidentifier
判断是否是一个合法的变量名
print("a23".isidentifier())
islower
判断字母是否都小写
print("Aa123".islower())
isupper
判断字母是否都大写
print("Aa123".isupper())
isnumeric
判断是否是只有数字
print("123".isnumeric())
isspace
判断是否是空格
print(" 123".isspace())
istitle
判断每个子字符是否是大写
print("My Name Is".istitle())
isprintable
是否可以打印,linux中终端设备文件不可以打印,返回假
print("123".isprintable())
join
字符串拼接join,该方法很重要
#将列表中元素拼接在一起,可以在中间指定特定字符串 print( ','.join(['1','2','3'])) name = ' ' print(name.join(['wang','cheng','liang'])) #可迭代对象必须都是字符串 #将列表中各个元素通过__连接成字符串 name1 = ['wang','cheng','liang'] newname='__'.join(name1) print(newname)
ljust
打印字符串长度为50 不够再后面以指定字符填充
print("My Name Is".ljust(50,'w'))
rjust
打印字符串长度为50 不够再前面以指定字符填充
print("My Name Is".rjust(50,'w'))
upper
小写变大写
print("abc".upper())
lower
大写变小写
print("ABCD".lower())
lstrip
去掉左边的回车或空格
print(" \nerf".lstrip())
rstrip
去掉右边的回车或空格
print("fgh\n ".rstrip())
strip
去掉左右两边的空格和回车
print(" \ntt\n ".strip())
translate
加密字符串
p = str.maketrans('qwert','12345') print("wanger".translate(p)) print(p)
replace
字符串中子字符替换
#替换指定的字符或字符串 print("abc".replace('a','1')) name='wangchengliang' #替换所有位置ng为'王' print(name.replace('ng','王')) #替换第一次出现的'ng'为王 print(name.replace('ng','王',1))
rfind
找到最右边的字符或字符串的下标
print("qweer12".rfind('e'))
split
按照指定的条件分割形成列表
print("qwew qe13".split(' ')) print("qwewqe13".split('e')) print("1+2+3+4+5+6".split('+'))
splitlines
按照换行符分割成列表
print("1234\nwerew".splitlines())
startswith
判断字符串是否以某个子字符或字符串开头
str1 = '#swangchengliang' #判断是否以#开头 print(str1.startswith('#'))
swapcase
大写变小写 小写变大写
print("qeeWwW".swapcase())
zfill
输出指定的字符串,不够以0填充
print("weqwe".zfill(10))
补充:
输出自己名字的二进制、十进制、十六进制
说明:
python3.5中,for循环字符串时,循环的每一个元素是字符
utf-8中一个字符等于3个字节
gbk 中一个字符等于3个字节
字符--->字节转换方式(bytes to str str to bytes)
name="王成亮" byte_list= bytes(name,encoding='utf-8')
将字符串转换成字节
b1 =bytes(name,encoding='utf-8') b2 =bytes(name,encoding='gbk') print(b1) print(b2)
将字节转换成字符串
b3 = str(b1,encoding='utf-8') b4 = str(b2,encoding='gbk') print(b3) print(b4)
将名字的二进制,十进制,十六进制方式输出
name = "王成亮" for n in name: #utf-8中一个汉字3个字节,默认打印每个汉字 print(n) #将字符转换为byte类型,输出16进制 byte_list_n= bytes(n,encoding='utf-8') print(byte_list_n) #循环字符类型输出十进制,使用bin()方法输出二进制 for b in byte_list_n: print(b,bin(b))