深入探索Python字符串:技巧、方法与实战

在这里插入图片描述

系列文章目录

  1. Python数据类型:编程新手的必修课
  2. 深入探索Python字符串:技巧、方法与实战
  3. Python 函数基础详解
  4. Python正则表达式详解:掌握文本匹配的魔法
  5. Python文件操作宝典:一步步教你玩转文件读写
  6. Python面向对象基础与魔法方法详解
  7. Python面向对象进阶:深入解析面向对象三要素——封装、继承与多态
  8. Python进阶之旅:深入理解变量作用域、垃圾回收、拷贝机制与异常处理
  9. Python函数进阶:四大高阶函数、匿名函数、枚举、拉链与递归详解
  10. 从零开始学迭代器生成器:打造高效、易读的Python代码
  11. Python进阶:深入剖析闭包与装饰器的应用与技巧
  12. PyMySQL:连接Python与MySQL的桥梁

概念

字符串: 由一系列字符组成的不可变序列容器

不可变:
	1.没有增删改方法
	2.所有的操作都不会直接作用于原数据
序列:
	有序的排列,支持索引和切片操作

输入与格式化输出

输入:

input("提示语")
  input接收过来的数据类型就是一个字符串

格式化输出:

1.%格式化法:
	占位符:%s字符串    %d整型   %f浮点型(默认保留6位小数)   %.2f保留两位小数
	使用:在字符串最后  %(参数1,参数2……)    如果整个字符串中只有一个参数需要传递,可以省略()
2. format格式化法:
	占位符:{}
	使用:在字符串最后  .format(参数1,参数2……)
3.f格式化法:
	占位符:{参数}
	使用:在字符串最前  f

索引与切片

索引:

语法:字符串[索引]
特点:从左往右,从0开始;从右往左,从-1开始

切片:

语法:字符串[起始下标:结束下标:步长]
特点:
	1. 取头不取尾,取不到结束下标对应的数据
    2. 步长不写默认为1,步长可以是正负数
    3. 下标可以正负数混搭
    4. [n:m]:从下标为n的位置开始取到下标为m的前一位
    5. [n:]:从下标为n的位置开始取到字符串结尾
    6. [:m]:从字符串开头取到下标为m的前一位
    7. [:][::]:取整个字符串
    8. [::-1]:将整个字符串反转

常用方法

查询类方法

	1.index:str.index(substring, beg=0, end=len(string))返回开始的索引值
  	2.find:str.find(str, beg=0, end=len(string)) 返回开始的索引值
  	3.count:str.count(sub, start= 0,end=len(string)) 返回子串出现的次数

index():查找字符串中第一次出现的子字符串的位置

str.index(sub,start,end) ---返回整数
参数:
    sub —— 查找的子字符串
    start —— 索引的起始位置,默认为0
    end —— 索引的结束位置,默认为字符串的长度

find(): 找字符串中指定的子字符串sub第一次出现的位置,可以规定字符串的索引查找范围。若无则返回 -1。

str.find(sub,start,end) -> int 返回整数

参数:
- sub —要索引的子字符串。
- start —索引的起始位置。默认值为0- end —索引的结束位置。默认值为字符串长度len(str)[start,end) 不包括end。

rfind(): 查找字符串中指定的子字符串sub最后一次出现的位置,可以规定字符串的索引查找范围。若无则返回 -1。

str.rfind(sub,start,end) -> int 返回整数

参数:
- sub —要索引的子字符串
- start —索引的起始位置,默认值为0
- end —索引的结束位置。默认值为字符串长度len(str)[start,end) 不包括end。

count(): 统计字符串里某个字符出现的次数。

my_str.count(str, start=0, end=len(mystr))
参数:
    str —— 为要统计的字符(可以是单字符,也可以是多字符)
    star —— 为索引字符串的起始位置,默认参数为0
    end —— 为索引字符串的结束位置,默认参数为字符串长度即len(str)

判别类方法

    startswith:是否以某个字符串为开头
    endswith:是否以某个字符串为结尾
  	isupper:是大写字母吗
  	islower:是小写字母吗
  	istitle:字符串是标题化的吗
  	isalpha:是全字母吗
  	isalnum:是全字母或全数字或全字母数字吗
  	isdigit:是数字吗
	isspace:只包含空白字符(空格 /n /t等)吗

startswith(): 判断字符串是否以指定字符或子字符串开头。

str.endswith("suffix", start, end)str[start,end].endswith("suffix") 用于判断字符串中某段字符串是否以指定字符或子字符串结尾。

—> bool 返回值为布尔类型(True,False)

参数:

- suffix — 后缀,可以是单个字符,也可以是字符串,还可以是元组("suffix"中的引号要省略)。
- start —索引字符串的起始位置。
- end — 索引字符串的结束位置。

endswith(): 判断字符串是否以指定字符或子字符串结尾。

str.endswith("suffix", start, end)str[start,end].endswith("suffix") 
用于判断字符串中某段字符串是否以指定字符或子字符串结尾。
—> bool 返回值为布尔类型(True,False

isupper(): 检测字符串中的字母是否全由大写字母组成。(字符串中可包含非字母字符)。字符串中包含至少一个区分大小写的字符,且所有这些区分大小写的字符都是大写,则返回 True,否则返回 False。

str.isupper() -> bool 返回值为布尔类型(True,False

islower(): 检测字符串中的字母是否全由小写字母组成。(字符串中可包含非字母字符)字符串中包含至少一个区分大小写的字符,且所有这些区分大小写的字符都是小写,则返回 True,否则返回 False。

str.islower() -> bool 返回值为布尔类型(True,False

istitle(): 检测判断字符串中所有单词的首字母是否为大写,且其它字母是否为小写,字符串中可以存在其它非字母的字符。若字符串中所有单词的首字母为大写,且其它字母为小写,则返回 True,否则返回 False.

str.istitle() -> bool 返回值为布尔类型(True,False

isalpha(): 检测字符串是否只由字母组成。字符串中至少有一个字符且所有字符都是字母则返回 True,否则返回 False。

str.isalpha() -> bool 返回值为布尔类型(True,False

isalnum(): 检测字符串是否由字母和数字组成。str中至少有一个字符且所有字符都是字母或数字则返回 True,否则返回 False

str.isalnum() -> bool 返回值为布尔类型(True,False

isdigit(): 检测字符串是否只由数字组成.字符串中至少有一个字符且所有字符都是数字则返回 True,否则返回 False。

str.isdigit() -> bool 返回值为布尔类型(True,False

isspace(): 检测字符串是否只由空格组成。若字符串中只包含空格,则返回 True,否则返回 False。

str.isspace() -> bool 返回值为布尔类型(True,False

调整类方法

	capitalize:将字符串的第一个字符变大写,其他字母变小写
  	title:使字符串标题化(字符串中所有单词首字母大写,其他小写)
    upper:变成大写
    lower:变成小写
    center:该方法返回一个原字符串居中,并使用空格填充至长度 width 的新字符串。

capitalize(): 将字符串的第一个字母变成大写,其余字母变为小写。

str.capitalize()

title(): 返回一个满足标题格式的字符串。即所有英文单词首字母大写,其余英文字母小写。

str.title()

upper(): 将字符串中的所有小写字母转换为大写字母

str.upper()

lower(): 将字符串中的所有大写字母转换为小写字母

str.lower()

center(): 返回一个长度为width,两边用fillchar(单字符)填充的字符串,即字符串str居中,两边用fillchar填充。若字符串的长度大于width,则直接返回字符串str

str.center(width , "fillchar")
- width —— 指定字符串长度。
- fillchar —— 要填充的单字符,默认为空格。

操作类方法

	replace(str1,str2):把str1替换为str2
    split(str,num):以str分割字符串,num可以指定分割几次
    join:str.join(sequence):将序列中的元素以指定的字符连接生成一个新的字符串
    strip:只能删除开头或是结尾的字符,不能删除中间部分的字符
    ljust:返回一个原字符串左对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串
    rjust:返回一个原字符串右对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串

replace():把 mystr 中的 str1 替换成 str2,如果 count 指定,则替换不超过 count 次.

my_str.replace(str1, str2,  mystr.count(str1))

split():拆分字符串。通过指定分隔符sep对字符串进行分割,并返回分割后的字符串列表。

 str.split(sep=None, maxsplit=-1) [n] 
 参数:
	sep —— 分隔符,默认为空格,但不能为空即('')
	maxsplit —— 最大分割参数,默认参数为-1
	[n] —— 返回列表中下标为n的元素。列表索引的用法

join(): 将iterable变量的每一个元素后增加一个str字符串。

 sep.join(iterable)

- sep——分隔符。可以为空。
- iterable—— 要连接的变量 ,可以是 字符串,元组,字典,列表等。

strip(): 该函数的作用是去除字符串开头和结尾处指定的字符,不会去除字符串中间对应的字符

str.strip(chars)
参数:chars -- 要去除的字符 默认为空格或换行符。

lstrip(): lstrip() 方法用于截掉字符串左边的空格或指定字符。

str.lstrip(chars)
参数:chars--要去除的字符 默认为空格或换行符。

rstrip(): 删除 str 字符串末尾的指定字符(默认为空格)

str.rstrip(chars)
参数:chars --要去除的字符 默认为空格或换行符。

ljust(): 返回一个原字符串左对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串。如果指定的长度小于原字符串的长度则返回原字符串。

str.ljust(width, fillchar) -> str 返回一个新的字符串

- width —— 指定字符串的输出长度。
- fillchar—— 将要填充的单字符,默认为空格。

rjust(): 返回一个原字符串右对齐,并使用fillchar填充(默认为空格)至指定长度的新字符串。如果指定的长度小于原字符串的长度则返回原字符串。

 str.ljust(width, fillchar)

- width —— 指定字符串的输出长度。
- fillchar—— 将要填充的单字符,默认为空格。

补充

	 字符串 + 字符串    拼接
 	 字符串 * 数字      复制
     字符 in  字符串:判断字符是否在字符串中
  	 字符 not in  字符串:判断字符是否不在字符串中
  	 len(字符串):统计字符串的长度、统计字符串中字符的个数

在这里插入图片描述

  • 11
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值