字符串
字符串:是一个有序的字符的集合,用于存储和表示的基本的文本信息。
'内容'或 "内容" 中间包含的内容称为字符串
特性:
- 只能存放一个值
- 不可变
- 按照从左到右的顺序定义字符集合,下标从0开始顺序访问,有序
常用字符串的分割、长度、索引、切片
去除空格:
str.strip():删除字符串当前行首尾的的空格
>>> a = ' hello '
>>> print(a.strip())
hello
>>>
str.lstrip():删除字符串左边的空行,默认为空格
>>> a = ' hello '
>>> print(a.lstrip())
hello
>>>
str.lstrip():删除字符串右边的空行,默认为空格
>>> a = ' hello '
>>> print(a.rstrip())
hello
>>>
查找字符串
str.index()和str.find()功能相同,区别在于find()查找失败会返回-1,不会影响程序运行,字符串一般用find,都可指定范围查找。
>>> a = "hello world"
>>> print(a.index('w',0,-1))#0 ,-1 从开始到结束,获取w在字符串中的那个位置
6
>>> print(a.find('w',0,-1))
6
>>> print(a.find('xx',0,-1)) #找不到该值 ,返回-1
-1
>>> print(a.index('xx',0,-1)) #直接报错
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: substring not found
>>>
字符串长度
>>> a = "hello world"
>>> print(len(a))
11
>>>
字符串大小写转换
>>> a = "Hello World"
>>>
#str.lower 把字符串全部转换为小写
#str.upper 把字符串全部转换为大写
#str.swapcase 把字符串中的大小写互换
#str.capitalize 字符串的首字母大写
>>>print(a.lower())
hello world
>>> print(a.upper())
HELLO WORLD
>>> print(a.swapcase())
hELLO wORLD
>>> print(a.capitalize())
Hello world
>>>
把字符串放入中心位置可指定长度及位置的两边字符
#str.center()
>>> a='hello world'
>>> print(a.center(40,'*'))
**************hello world***************
字符串统计
#str.count()
>>> a='hello world'
>>> print(a.count('l')) #统计l在字符串中有几个
3
字符串的测试、判断函数,这一类在string模块中没有,这些函数返回的都是bool值
Str.startswith(prefix[,start[,end]]) #是否以prefix开头
Str.endswith(suffix[,start[,end]]) #以suffix结尾
Str.isalnum() #是否全是字母和数字,并至少有一个字符
Str.isalpha() #是否全是字母,并至少有一个字符
Str.isdigit() #是否全是数字,并至少有一个字符
Str.isspace() #是否全是空白字符,并至少有一个字符
Str.islower() #S中的字母是否全是小写
Str.isupper() #S中的字母是否便是大写
Str.istitle() #S是否是首字母大写的
字符串切片
str = '0123456789'
print (str[0:3]) #截取第一位到第三位的字符
print (str[:] )#截取字符串的全部字符
print (str[6:]) #截取第七个字符到结尾
print (str[:-3] )#截取从头开始到倒数第三个字符之前
print (str[2]) #截取第三个字符
print (str[-1] )#截取倒数第一个字符
print (str[::-1]) #创造一个与原字符串顺序相反的字符串
print (str[-3:-1] )#截取倒数第三位与倒数第一位之前的字符
print (str[-3:]) #截取倒数第三位到结尾
print (str[0:10:2])#每隔一个,取一个值
print (str[0:10:3])#每隔2个,取一个值
字符串替换
#str.replace()默认替换字符串的所有值
>>> a = "Hello World"
>>> print(a.replace('l','F'))#把字符串中的把l全部替换成F
HeFFo WorFd
>>> print(a.replace('l','F',1))#只替换字符串中的第一个l替换成F
HeFlo World
>>>
字符串分离
>>> a = "Hello World"
>>> print(a.split())#默认按空格把字符串分为两个值,分离成列表,也可以按照指定的值,分离
['Hello', 'World']
字符串格式化str.format()和str.formap_map()
str.format()#用法介绍
#根据{name} ,特定的值来格式化(常用)
test = 'i am {name}, age {a}'
print(test)
v = test.format(name='yangjian',a=19)
print(v)
#执行结果
i am {name}, age {a}#格式化之前的值
i am yangjian, age 19 #格式化之后的值
#根据格式化的循序,来传入相应格式化顺序的值
test = 'i am {0}, age {1}'
print(test)
v = test.format('xixi',19)
print(v)
#执行结果
i am {0}, age {1}#格式化之前的值
i am xixi, age 19#格式化之后的值
str.format_map()#用法介绍
#.format_map,传入的值 {"name": 'yj', "a": 19} key:value 值来传入
test = 'i am {name}, age {a}'
v1 = test.format(name='df',a=10)
v2 = test.format_map({"name": 'yj', "a": 19})
print(v1)
print(v2)
#执行结果
i am df, age 10
i am yj, age 19
str.expandtabs(tabsize=)
该方法返回字符串中的 tab 符号('\t')转为空格后,生成的新字符串。
tabsize -- 指定转换字符串中的 tab 符号('\t')转为空格的字符数。
name = "name\tage\thobby\t"
v = name.expandtabs(20) #20 可以用tabsize=20表示 ,每个\t转换后有20个字符,没有20个字符则用空格表示,
#如果该\t前面字符有20个,
#则\t需要转换后要有20个空格的字符。
print(v)
print(len(v))
#打印结果
name age hobby
60
name = "name\tage\t12345678\t"
res = name.expandtabs() #每个\t 默认转换后一共有8个字符,不够用空格表示
print(len(res))
print(res)
str.join(iterable)按照可迭代(iterable)的对象,根据某个元素进行连接
#按照可迭代的对象,根据某个元素进行连接
#这里是可迭代的元素,根据下划线进行连接成一个字符串
name = "yangjian"
n = "_".join(name)
print(n)
#打印结果
y_a_n_g_j_i_a_n