2022年12月python的字符串常用操作

news2024/11/16 16:36:03

字符串在整整个开发的过程中,使用频率相对来说是较高的。
在此总结几个字符串的常用操作, 字符串的操作,转换后即生成为新字符串
【长度统计
切片:

根据索引进行切片str[开始索引:结束索引:步长]
根据指定标识符进行切片str.split(‘标识符’,切割次数),返回一个数组,如果标识符不存在,则将整个字符串返回一个数组,且元素只有一个

替换:replace ,当替换次数为空时,替换次数默认为全部替换
ste.replace(‘旧元素’,‘新元素’,‘替换次数’)
将字符串的’o’进行替换
在这里插入图片描述
将字符串中‘o’第一次出现的位置替换为大写的Y,即为替换一次
在这里插入图片描述
查找

1、根据索引查找元素 :str[索引] 打印出来的为字符串中指定索引的字符
2、根据字符查找索引:str.index(‘字符’),次数输出位字符所以的索引值
ps:根据字符查找索引时,如果输入的多个连贯字符,则返回的索引为第一个字符的索引
在这里插入图片描述
3、系统中还给出find(’字符‘,’步长‘),默认从左侧查找,默认步长为1,返回最所在的索引值
rfind(’字符‘,’步长‘)方法,从右侧查找,默认步长为1,返回字符所在的索引值
在这里插入图片描述

ps:字符查找本人习惯用.index()函数,不过还是推荐使用find()或者rfind()详见下边总结
统计:count(),个人习惯用法是:判断某个字符出现的次数,根据次数进行字符串切割

print(str.data.count('o'))

在这里插入图片描述
判断:判断类返回结果为True或者为False
1、是否为数字,isdigit()
在这里插入图片描述
2、是否为字符,isalpha()即为【a-z,A-Z】
在这里插入图片描述
3、是否为字母或数字或者为字母和数字的组合:isalnum()即为【a-z,A-Z,0-9】
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
4、判断是否以某个字符开始或者结束startswith(‘字符’),endstwih(‘字符’)
在这里插入图片描述
在这里插入图片描述

ps:以上判断方法仅用于简单的判断,较为复杂的判断使用正则表达式
全部转为大写upper()
在这里插入图片描述
全部转为小写lower()
在这里插入图片描述
首字母转为大写capitalize()
在这里插入图片描述

例子:str_data = 'welcome to my room
1、统计字符换的长度。

str_leng = len(str_data)
print(str_leng)

用ipython的运行结果如图
在这里插入图片描述
统计字符串的长度有什么作用呢?举例子,判断手机号的长度是否为11位(仅仅是其中一个案列哦,后期判断手机号是可以通过正则表达式或者其他库来进行验证的)

phone = input('请输入手机号')
# 通过input输入的内容均为字符串
if len(phone) == 11:
	print('位数够了,开始进行其他判断')
else:
	print('兄弟,认真点可好,手机号要11位哦')

在这里插入图片描述
在这里插入图片描述
2、字符串的切片,可以使用str[开始索引:结束索引:步长],也可以使用split
只获取以上字符串的welcome
1、使用str[开始索引:结束索引:步长]方式,注意:切取的最后一位是结束索引-1。

new_str = str_data[0:8:1] #完整写法
print(new_str)

在这里插入图片描述
以上方法可以简写为:

new_str2 = str_data[:8]
print(new_str2)

在这里插入图片描述
以上方法默认的开始索引为0,步长为1
下面,还是使用这种方法,做如下要求,截取该字符串的前10位,要求每隔1个字符串截=取一个
分析:截取前10位,开始索引为0,结束索引为10+1,即为11,每隔1个字符串截取一个,步长为2

new_str3 = str_data[0:11:2]
print(new_str3)

在这里插入图片描述
ps:步长个人的理解为:两个相邻字符的索引相减。如果步长为正数,则是从左向右开始截取,如果步长为负数,则是从右向左截取。

new_str4 = str_data[0:8:-2]
print(new_str4)
new_str5 = str_data[11:8:-2]
print(new_str5)

在这里插入图片描述

print(str_data[11])
print(str_data[8])

在这里插入图片描述
ps:步长为负数索引时,截取的字符串也为原字符串的反转,如下,我们将截取字符串的room,并做反转

new_str6 = str_data[-1:-5:-1]
print(new_str6)

在这里插入图片描述
尝试一下其他方式 突如其来的想法
1、截取任意字符,任意长度
思路:查找开始字符的索引,查找结束字符的索引,根据步长进行截图
例子:截取字符串中‘e’第一次出现的位置,至第一次‘r’出现的位置,以步长为1进行截取
ps:查找字符的索引用:str.index(‘字符’)

# 首先查找e第一次出现的位置
str_e = str_data.index('e')
print(str_e)

在这里插入图片描述

# 查找r第一次出现的位置
str_r = str_data.index('r')
print(str_r)

在这里插入图片描述

new_str7 = str_data[1:15:1] # 步长为1时,可以不用写,系统默认的步长为1,可以写成:new_str7 = str_data[1:15]
print(new_str7)

在这里插入图片描述
扩展1:截取以上字符串中的room,将按照逆序输出
思路:通过查看字符串得知,room为字符串的最后一位,即开始索引为len(str_data)-1
,再统计room的长度为len(‘room’),即结束索引为len(str_data)-len(‘room’)-1,逆序时,步长为-1,由此得出:

start_index = len(str_data) - 1
end_index = len(str_data) - len('room') - 1
str_room = str_data[start_index:end_index:-1]
print(str_room)

在这里插入图片描述
2、用split进行字符串切片 通过指定分隔符对字符串进行切片
str.split(str=“”, num=string.count(str)).
参数
str – 分隔符,默认为所有的空字符,包括空格、换行(\n)、制表符(\t)等。
num – 分割次数。默认为 -1, 即分隔所有。

str_split_01 = str_data.split()

在这里插入图片描述
在这里插入图片描述
ps: split()的主要是以某种字符为标识进行切割,第二个参数为切割几次
举例:
第一:str_data字符串,以‘o’为切割标识进行切割,切割次数为系统默认,则,字符串中有多少个‘o’就进行多少次的切割,切割后返回一个列表

str_split_o = str_data.split('o')
print(str_split_o)

在这里插入图片描述
第二:字符串依旧以’o’为切割标志,切割次数为1次,如下

str_split_o_one = str.data.split('o',1)
print(str_split_o_one)

在这里插入图片描述
ps:切割后得到的元素个数为切割次数+1,如上,切割一次,得到了两个元素
个人理解的split()的用法应该是常用如长字符串以某种符号进行切割时使用。
总结:
1.统计长度len(str)
2.统计次数str.count(‘string’)
3.查找字符所在位置
str.index(‘string’),
str.find(‘string’,‘startindex’,‘endindex’),str.rfind(‘string’,‘startindex’,‘endindex’)
在这里插入图片描述
区别为:find()/rfind()查找不到时返回-1,index()查找不到时返回错误
4.判断类:
是否为数字isdigit()
是否为字母isalpha()
是否为数字或者字母或者数字和字母的组合isalnum()
是否为某个字符开始:startswith()
是否为某个字符结束:endswith()
5.切片
str[start,end,step],staert 默认为0,step默认为1,当step位负数是,则为字符串反转
str.split(‘str’,count) 系统默认为空格,换行符为切割对象,默认次数为全部切割
6.遍历

for str in string:
	print(str)

暂时总结这么多,有想到的再来做补充

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/96858.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【码极客精讲】桶排序

桶排序 (Bucket sort)或所谓的箱排序,是一个排序算法,工作的原理是将数组分到有限数量的桶子里。每个桶子再个别排序(有可能再使用别的排序算法或是以递归方式继续使用桶排序进行排序)。桶排序是鸽巢排序的一种归纳结果。当要被排…

【硬币识别】形态学硬币计数【含Matlab源码 683期】

⛄一、硬币图像识别简介 本设计为硬币图像识别统计装置,通过数码相机获取平铺无重叠堆积的硬币的图像,并通过Matlab工具处理后统计硬币的数目。 1 图像格式转换 取的图像格式为RGB彩色图像,需要先将其转换为8位256级的灰度图像。本程序采用…

SAP Gateway 里的 REST 概念

SAP Gateway 有助于轻松配置和使用 SAP Business Suite 系统的业务逻辑和内容,用于移动和 Web 应用程序。它降低了访问 SAP 数据所需的复杂性和技能组合,从而消除了部署障碍。使用简单的界面有助于缩短开发时间。 SAP Gateway 使以人为本的应用程序能够…

【笔记:模拟CMOS集成电路】MOS特性仿真分析

【笔记:模拟CMOS集成电路】MOS特性仿真分析前言一、电路图二、电路仿真(1)Ids与Vds的关系仿真仿真结果仿真结果分析(2)Ids与Vgs的关系仿真仿真结果仿真结果分析前言 本文为本人学习模拟集成电路相关知识的的学习笔记&a…

USB接口WIFI(MT7601芯片)的驱动源码移植过程详解(驱动源码编译、wpa_supplicant工具交叉编译、文件系统移植)

1、MT7601的移植步骤 (1)确认你的WT7601网卡硬件是正常的; (2)修改驱动源码,依赖内核源码树编译并加载; (3)交叉编译wpa_supplicant工具,移植到根文件系统里; (4)添加驱动和wpa_supplicant工具依赖的配置文件&#xff…

2022 年时间序列分析最顶流的 Python 库

时间序列分析是一种强大的工具,可用于从数据中提取有价值的信息并对未来事件进行预测。它可用于识别趋势、季节性模式和变量之间的其他关系。时间序列分析还可用于预测未来事件,例如销售、需求或价格变动。 如果你在 Python 中处理时间序列数据&#xf…

数据库实验三:完整性语言实验

实验三 完整性语言实验 实验 3.1 实体完整性实验 1.实验目的 ​ 掌握实体完整性的定义和维护方法。 2.实验内容和要求 ​ 定义实体完整性,删除实体完整性。能够写出两种方式定义实体完整性的SQL语句;创建表时定义实体完整性、创建表后定义实体完整性…

C++ Reference: Standard C++ Library reference: Containers: map: map: key_comp

C官网参考链接&#xff1a;https://cplusplus.com/reference/map/map/key_comp/ 公有成员函数 <map> std::map::key_comp key_compare key_comp() const;返回键比较对象 返回容器用于比较键的比较对象的副本。map对象的比较对象在构造&#xff08;construction&#xff…

kubernetes 挂载传播

kubernetes 挂载传播 kubernetes 的 mountPropagation 翻译成中文就是挂载传播。挂载传播提供了共享卷挂载的能力, 它允许在同一个 Pod, 甚至同一个节点内, 在多个容器之间共享卷的挂载。 说白了就是在容器或 host 内的挂载目录中 再 mount 了一个别的挂载。 kubernetes 中 卷…

第18章 条件概率

第18章 条件概率 18.1蒙特霍尔困惑 对于上一章的三个门的问题&#xff0c;有一个漏洞。假设参赛者选择门A且门B后有一只山羊&#xff0c;刚好产生3个结果&#xff1a; 以上结果出现的概率分别是1/18,1/18,1/9。 在这些结果中&#xff0c;只有最后一个结果(C,A,B)&#xff0c…

Redis常见面试题(三)

目录 1、Redis String值最大存储多少? 2、Redis事务有什么用? 3、Redis事务相关的命令有哪几个? 4、Redis事务是原子性的吗? 5、Redis持久化有什么用? 6、Redis有哪几种持久化方式? 7、Redis持久化方式如何选择? 8、如何保证Redis中的数据都是热点数据? 9、Red…

vue前后端分离项目打包成app,部署成移动端

将vue项目打包成app,在手机上运行。 1. vue打包 npm run build 先将vue的前端项目打包成dist文件夹 2. 安装hbuilderX Hbuilder官网地址 3. hbuilderX 1&#xff09;新建项目 我是vue的&#xff0c;所以直接选择的h5app&#xff0c;然后起个名字&#xff0c;选择路径。 2…

微服务实用篇6-分布式搜索elasticsearch篇2

今天我们继续学习分布式搜索引擎elasticsearch&#xff0c;今天主要学习四个模块&#xff0c;分别为DSL查询文档&#xff0c;搜索结果处理&#xff0c;RestClient查询文档&#xff0c;还有最好演示一个旅游案例。下面开始今天的学习吧。 目录 一、DSL查询文档 1.1、DSL查询分…

Hadoop学习----软件安装

Hadoop源码下载重新编译 软件下载&#xff1a;https://hadoop.apache.org/releases.html 建议是下载源码包。 源码包和官方编译安装包有什么不一样呢&#xff1f; 正常情况下&#xff0c;非生产环境直接使用官方编译安装包即可&#xff0c;但是官方提供的安装包不支持本地库。…

ANTLR4入门(二):图示说明eclipse安装Antlr4IDE插件的过程

如果你能正常通过Eclipse Market找到antlr4的插件并正常安装&#xff0c;可以忽略本文。 如果不能&#xff0c;那多半是因为网络问题导致安装Antlr4IDE插件时无法下载文件造成的。我就遇到了这个问题&#xff0c;无法下载的原因很复杂&#xff0c;我不想去深究了&#xff0c;我…

WPF/XAML关于x:key和x:name的区别,全面解读超详细

x:key和x:name的区别 x:Keyx:Name用于xaml Resources&#xff0c;ResourceDictionary用在ResourceDictionary以外任何地方使用key访问xaml指定对象使用name访问xaml对象标识资源创建和引用&#xff0c;存在于 ResourceDictionary 中的元素唯一标识对象元素&#xff0c;以便于从…

【Spring】SpringCloud

目录 一、SpringCloud 二、微服务介绍 1.系统架构演变 1.1 单体应用架构 1.2 垂直应用架构 1.3 分布式架构 1.4 SOA架构&#xff08;面向服务的架构&#xff09; 1.5 微服务架构&#xff08;服务的原子化拆分&#xff09; 2.微服务架构介绍 2.1 问题&#xff1a; 2.2…

与新手一起快速了解「什么是次世代」?

次世代&#xff08;英文&#xff1a;Next Generation&#xff09;&#xff0c;源自日本语&#xff0c;即下一个时代&#xff0c;未来的时代。与传统游戏相比&#xff0c;次世代游戏是把次世代游戏开发技术融入到现代游戏之中&#xff0c;通过增加模型的面数和贴图的数据量并使用…

JDK8系列之使用Function函数式接口

一、函数式接口是jdk8的新特性之一&#xff0c;函数式接口是只包含一个抽象方法声明的接口。按分类主要分为四大接口类型: Function、Consumer、Predicate、Supplier。 接口参数返回值说明Supplier<T>无T供给型&#xff0c;无参&#xff0c;返回一个指定泛型的对象Consu…

设计解谜游戏的30堂课

设计解谜游戏的30堂课 文章目录1.什么是Eureka Moment&#xff1f;2.谜题与幽默是同构的3.最大限度提高Sparkle4.避免无意义的谜题5.惊喜是Sparkle的重要源泉6.有趣的事实是惊喜的源泉7.尤里卡时刻并不是自豪8.不同解密者所寻求的解密体验是不尽相同的9.尤里卡是可以分享的10.创…