赞
踩
#capitalize 字符串首字母大写
strvar = "how are you"
res = strvar.capitalize()
print(res)
#title 每个单词的首字母大写
strvar = "how old are you"
res = strvar.title()
print(res)
#*upper 将所有字母变成大写
strvar = "How Old Are You"
res = strvar.upper()
print(res)
#*lower 将所有字母变成小写
res = strvar.lower()
print(res)
#*swapcase 大小写互换
strvar = "How old Are You"
res = strvar.swapcase()
print(res)
#*len 计算字符串的长度
strvar = "python32真热"
res = len(strvar)
print(res)
#*count 统计字符串中某个元素的数量 ,不存在返回0,不报错
"""count(字符,[开始值,结束值])"""
strvar = "真热真热呀"
#res = strvar.count("真") # 2
#res = strvar.count("热",2) # 1 只有一个数,是开始位置
#res = strvar.count("热",2,3) # 只有真这个字符 没有热
print(res)
#*find 查找某个字符串第一次出现的索引位置 (推荐)
"""find(字符,[开始值,结束值])"""
strvar = "To be or not to be that is a question"
res = strvar.find("to")
res = strvar.find("be",4)
#如果find 返回的是 -1 代表没找到
res = strvar.find("be",4,10) # 4 ~ 9
print(res)
打印出第一个to中 t出现的下标
#*index 与 find 功能相同 find找不到返回-1, index找不到数据直接报错。不推荐使用 """ res = strvar.index("be",4,10) print(res) """ #*startswith 判断是否以某个字符或字符串为开头 """ startswith(字符,[开始值,结束值]) endswith(字符,[开始值,结束值]) """ strvar = "To be or not to be that is a question" res = strvar.startswith("To") res = strvar.startswith("To",10) print(res)
#*endswith 判断是否以某个字符或字符串结尾
res = strvar.endswith("question")
res = strvar.endswith("is",-14,-11) # is 只能正向表示
print(res)
#is系列
#*isupper 判断字符串是否都是大写字母 ,有其他文字,特殊符号不影响,只看英文字母是否大写
strvar = "HOW A YOU"
res = strvar.isupper()
print(res)
#*islower 判断字符串是否都是小写字母
strvar = "asdf - as"
res = strvar.islower()
print(res)
#*isdecimal 检测字符串是否以数字组成 必须是纯数字,有小数点都不算纯数字。如果要判断是否是小数,可用isinstance()
strvar = "abcdefg"
strvar = "2134234.123"
strvar = "2134234"
res = strvar.isdecimal()
print(res)
#isdigit 判断字符串是否是数字组成,接受二进制字节流
#isnumeric 检测字符串是否以数字组成,中文的数字比如"四",也被认为是数字
#isalnum 判断字符串是否由数字,字母,汉字组成
#isalpha 判断字符串是否由字母和文字组成
#isspace 判断字符串是否由空白符组成。空串不是空白符
#split 按某字符将字符串分割成列表(默认字符是空格)
split():拆分字符串。通过指定分隔符对字符串进行切片,并返回分割后的字符串列表(list)
1、split()函数
语法:str.split(str=“”,num=string.count(str))[n]
参数说明:
str:表示为分隔符,默认为空格,但是不能为空(‘’)。若字符串中没有分隔符,则把整个字符串作为列表的一个元素
num:表示分割次数。如果存在参数num,则仅分隔成 num+1 个子字符串,并且每一个子字符串可以赋给新的变量
[n]:表示选取第n个分片
注意:当使用空格作为分隔符时,对于中间为空的项会自动忽略
返回的是列表,丢失分割字符
分隔后取得值的类型是str,就是通过列表的下标取值
strvar = "you can you up no can no bb"
lst = strvar.split()
strvar = "you#can#you#up#no#can#no#bb"
lst = strvar.split("#")
print(lst)
截取字符串中想要的字段
#join 按某字符将列表拼接成字符串(容器类型都可)
join()将多个序列中的元素合并成一个新的字符串
join(): 连接字符串数组。将字符串、元组、列表、集合中的元素以指定的字符(分隔符)连接生成一个新的字符串
语法:
子串或字符.join(多个字符串组成的序列)
lst = ['you', 'can', 'you', 'up', 'no', 'can', 'no', 'bb']
strvar = " ".join(lst)
strvar = "#".join(lst)
print(strvar)
集合顺序会乱,不建议用
#replace 把字符串的旧字符换成新字符
“”“字符串.replace(‘旧字符’,‘新字符’[, 限制替换的次数])”“”
字符串序列.replace(“原字符串”,“新字符串”,修改的次数)
如果查到出现的次数,就从左到右替换该次数,省略不写次数,全部替换,次数超过了,也不报错,全部替换
replace有返回值,返回值就是修改后的字符串
但是,字符串是不可以修改的类型,它并没有修改以前的str
并不会将原有字符串修改,将替换后的结果赋值给新字符串,才得到修改后的字符串
strvar = "范冰冰爱不爱我,爱我,不爱我,爱我,不爱我"
res = strvar.replace("不爱我","爱我")
#选择替换的次数
res = strvar.replace("不爱我","爱我",1)
print(res)
#strip 默认去掉首尾两边的空白符
“”“空白符 空格 \n \t \r … “””
Python 的 strip() 方法用于移除字符串头尾指定的字符(默认为空格或换行符)或字符序列。
注意:该方法只能删除开头或是结尾的字符,不能删除中间部分的字符。
strip() 方法语法
str 是字符串,chars 是指定的字符。
str.strip([chars]);
参数:
chars – 移除字符串头尾指定的字符序列。可以指定去除的内容
返回值:
返回移除字符串头尾指定的字符后生成的新字符串。
如下,去除字符串两边的"景"
strvar = " 周润发 "
res = strvar.strip()
print(strvar)
print(res)
#zfill 填充字符串(默认填充0,原字符串右对齐)
①语法说明:
str.zfill(width)
其中,str表示这里要对一个字符串类型string进行操作,如果是整型、浮点型这样的数字类型,要先通过str()函数转化为字符串,才可以进行相关的操作;
width表示进行补零之后的字符串的长度,如果补零后的长度小于或等于原字符串的长度,那么字符串将不会产生任何的变化
Python中的ljust()和rjust()方法属于字符串格式控制方面的函数。这两个方法按照指定的字符串宽度和特定字符来调整字符串宽度,若字符串不足指定的宽度就用指定的字符来填充剩余的宽度。
一、ljust()和rjust()语法格式
str.ljust(width [, fillchar] )
str.rjust(width [, fillchar] )
上面中str即为要操作的字符串;
width 是指定的填充后的总宽度,若 width 小于或等于原字符串的宽度,则原样返回原字符串;
fillchar是可选参数,即要填充的字符,默认为ASCII空格,即相当于按下键盘中的空格键产生的空格。
这两个方法执行完会产生一个新的字符串,不影响原字符串的内容。
(1)ljust()方法使原字符串位于新字符串的左端,不足指定的宽度,则在右侧填充指定的字符:字符串左齐
(2)rjust()方法使原字符串位于新字符串的右端,不足指定的宽度,则在左侧填充指定的字符:字符串右齐
#ljust 填充字符串,原字符居左 (默认填充空格)
#rjust 填充字符串,原字符居右 (默认填充空格)
指定的宽度不足,就打印原字符串
*#center 填充字符串,原字符居中 (默认填充空格)
“”“center(字符长度,填充符号)”“”
strvar = "赵世超"
res = strvar.center(10)
#res = strvar.center(10,"*")
print(res)
print结束符:
Python的print()自带end="\n"这个换行结束符,所以,两个print会换行展示,
我们也可以根据需要自定义结束符
print('输出的内容', end="\n")
print("hello", end="...")
print("world!")
print("hello", end="\t")
print("python!")
输出结果
hello...world!
hello python!
python字符串:
在python中引号引起来的就是字符串,双引号,单引号,三引号都可以
三引号支持回车换行,输出的也是换行的
字符串是用来存储少量数据
字符串是不可变类型
单引号有其他用途时,需要转义
c = 'I\'m Tom'
print(c)
#(3)字符串跨行拼接 \
str1 = "kskfjskjfklsjfklasdjklfjaskldjfaskljfklasjdfklasjdklfjaskldfjaskldjflasjfsf" \
"1122334"
字符串输入用input
输入功能:
input(“提示信息”)
当程序执行到input时,等待用户输入,输入完成后才能继续向下执行
在python中,input接收用户输入后,一般存储到变量,方便调用
在python中,input会把接收的任意输入的数据都当做字符串处理
索引:
索引(下标) 通过索引可以快速精确的定位到某个元素
name = "meat"
meat 每一个字母叫做一个元素
#0123 从左向右代表每一个字母
#-1-2-3-4 从右向左每一个字母
print(meat[1]) 打印出meat字符串的第二个字符
负索引
name = "todayisgood"
print(name[0:2]) 输出:to
顾头不顾尾 name[起始位置:终止位置:步长] 不包含最后一个
左闭右开,默认步长为1
print(name[:]) 返回所有字符串
某个位置不指定的时候默认取最后或最前
print(name[:3]) 输出:tod
print(name[2:5]) 输出:day
从左到右截,间隔值为正值,反过来,间隔值是负值,才能保证截取到数据
res = strvar[-3:-10:10] # 错误的逻辑,没有输出
正序,要从左往右截取,才能截取到
#从左向右截取
res = strvar[::3]
#0 3 6 9 12 15 ... 步长3,隔两个取一个,根据下标取值
print(res)
str1 = '(223+4343*3245)'
#步长为1,输出到倒数第二个的全部数据,不包含倒数第二个
print(str1[:-2])
(223+4343*324
print(str1[-5:-2])
324
print(name[-2:-5])
print(name[-2:-5:-1])
#[起始位置:终止位置:步长] 步长默认为1**
print(name[100:105])
切片的时候起始位置和终止位置都超出的时候不会进行报错,超出不会打印出来
print(name[100])
索引的时候索引值超出范围的时候会报错
获取s字符串中所有内容
s[:]
获取s字符串中第4个到最后一个,每2个取一个
s[3::2]
获取s字符串中倒数第5个到最开始,每3个取一个
s[-5::-3]
步长为负数,倒序输出
步长为负数时,若选取了起始末尾位置,选取顺序也要倒叙,不然没输出
str1 = "0123456789"
print(str1[-6:-9:-1])
name = "Jinghao nihao"
print(name[::2])
输出:Jnhonho
常见的字符串操作函数:
替换:
name = "Jinghao nihao"
name1 = name.replace("n", "8") 将name中所有的n替换成8
name1 = name.replace("n", "8", 1) 将name中第一个n替换成8
大小写反转:
name = "JerryHome"
print(name.swapcase())
输出 jERRYhOME
查找
在字符串中查找子串的位置或出现的次数
字符串.find(子串,开始位置下标,结束位置下标) 开始和结束位置下标也可以省略,整个字符串中查找
name = “jerry”
print(name.find(“r”))
输出 2 (代表第一个"r"的下标)
#返回子串首个字符开始位置的下标
name = “I love you china, my nema is Jinghao”
print(name.find(“you”))
输出:7
print(name.find(“t”))
输出 -1 (find 查找不存在的返回 -1)
index与find使用方法一样
print(name.index(“t”))
index 查找不存在的就报错
rfind findex 查找方向从右侧开始查找
name = “I love you china, my nema is Jinghao, I love peace”
print(name.rfind(“love”))
输出:40
返回的是从右边开始查找的第一个出现的位置,下标从左边开始计算的
不存在返回-1
count()返回某个子串出现的次数,不存在返回0,不报错
name = “I love you china, my nema is Jinghao, I love peace”
print(name.count(“love”))
输出:2
列表也可用这些方法
字符串序列.replace(“原字符串”,“新字符串”,修改的次数)
如果查到出现的次数,就从左到右替换该次数,省略不写次数,全部替换,次数超过了,也不报错,全部替换
replace有返回值,返回值就是修改后的字符串
但是,字符串是不可以修改的类型,它并没有修改以前的str
并不会将原有字符串修改,将替换后的结果赋值给新字符串,才得到修改后的字符串
替换:
name = "Jinghao nihao"
name1 = name.replace("n", "8") 将name中所有的n替换成8
name1 = name.replace("n", "8", 1) 将name中第一个n替换成8
分割:split
语法:
字符串序列.split(分隔符号,num) 默认是以空格为分隔符
num表示分隔符出现的次数,即将来返回的数据是num+1个
不写num,就是将出现分隔符的地方都分割
返回的是列表,丢失分割字符
#split,分割字符
name = "I love you china, my nema is Jinghao, I love peace"
print(name.split("love", 2))
['I ', ' you china, my nema is Jinghao, I ', ' peace']
join()将多个序列中的元素合并成一个新的字符串
join(): 连接字符串数组。将字符串、元组、列表中的元素以指定的字符(分隔符)连接生成一个新的字符串
语法:
子串或字符.join(多个字符串组成的序列)
字符串拼接,以a为分隔符,将b拼接起来
#join
str2 = ["aa", "bb", "cc"]
print(" ".join(str2))
输出:aa bb cc
对序列进行操作(分别使用’ ‘与’:‘作为分隔符)
2
3 >>> seq1 = [‘hello’,‘good’,‘boy’,‘doiido’]
4 >>> print (’ ‘.join(seq1))
5 hello good boy doiido
6 >>> print (’:‘.join(seq1))
7 hello:good
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。