python字符串的四种表达(Python字符串类型介绍)
python字符串的四种表达(Python字符串类型介绍)
2024-11-05 11:12:49  作者:学会作弊  网址:https://m.xinb2b.cn/life/vpi534105.html

一、简介

字符串为Python中常用类型,与Java不同的是,Python既可使用单引号表示,也可使用双引号表示。如下面的例子:

a = "hello world"b = 'i am ok'

上述声明的a和b均为Python中合规的字符串表示形式。当然,若在Java中,单引号表示字符类型,双引号才表示字符串。

若此时使用type()函数来查看字符串的类型,会输出<class 'str'>。

二、下标

所谓下标其实就是索引。在Python中,可通过下标来获取指定位置的字符,如下面的例子:

name = "hello world"print(name[0])print(name[1])print(name[2])

执行结果如下:


这与Java有所不同。在Java中,若想获取指定位置的字符,只能通过字符串的charAt(int index)方法来获取,而非直接指定对应的位置。

三、获取子串

若需在Java中获取子串,则可通过字符串对象的subString方法来获取。而在Python中,获取子串则是通过所谓的切片操作来完成。所谓切片就是从待操作对象截取部分内层。除字符串外,列表、元组、集合等也都支持该操作。

其语法格式为:

序列[起始坐标:结束坐标:步长]

需要说明的是,使用切片功能时,并不会包含结束位置处的数据。若不指定结束坐标,则默认为序列的长度。若不指定步长,则默认为1。

下面为对应的例子:

s = "hello world"# 只指定起始位置print(s[6:])# 指定结束位置print(s[:5])# 指定起始位置和结束位置print(s[6: len(s)])s2 = "a b c d e f g"# 只指定步长print(s2[::2])# 指定起始位置、结束位置和步长print(s2[6: len(s2): 2])

执行结果如下:


此外,Python切片的起始位置和结束位置还支持负数。如下面的例子:

s = "hello world"# 只指定起始位置print(s[-5:])# 指定起始位置和结束位置print(s[-len(s): -6])

执行结果如下:


这与Java有所区别,因为在Java中,使用subString方法时,起始索引和结束索引均不支持负数。

四、常用方法

对于字符串常用的方法而言,大致可分为三类,分别是:查找、修改和判断。

4.1 查找

所谓查找就是查找某个子串在字符串中出现的位置或次数。下面简单介绍一下常用的查找方法。

find和rfind

find方法用于检测某个字符是否存在于该字符串中,若存在,则返回该子串开始处的下标;若不存在,则返回-1。而rfind与find作用类似,区别在于,rfind是从字符串的末尾开始向前进行查找。

下面为对应的语法格式:

# find字符串序列.find(子串, 开始位置下标, 结束位置下标)# rfind字符串序列.rfind(子串,开始处下标,结束位置下标)

需要说明的是,开始位置下标和结束位置下标均可进行省略,当开始位置下标省略时默认为0,当结束位置下标省略时默认为字符串的长度。

下面给出对应的示例:

s = "Tom and Jerry and Spike and Tuffy"print("首个and出现的位置:", s.find("and"))print("从下标7开始,and首次出现的位置:", s.find("and", 7))print("首个ands出现的位置:", s.find("ands"))print("从末尾开始,首个and出现的位置:", s.rfind("and"))print("从下标0开始,到倒数第12个字符结束,倒数首个and出现的位置:", s.rfind("and", 0, -12))

执行结果如下:


index和rindex

index方法用于检查某个子串是否被包含在该字符串中,若包含则返回子串开始位置下标,否则抛异常。rindex与index类似,只不过是从末尾开始查找而已。

这两个方法与Java中的indexOf和lastIndexOf方法有相似的作用。当然,indexOf和lastIndexOf无法指定结束位置下标,且起始位置下标不能指定为负数。

下面是对应的语法格式:

# index字符串序列.index(子串,开始位置下标,结束位置下标)#rindex字符串序列.rindex(子串,开始位置下标,结束位置下标)

需要说明的是,开始位置下标和结束位置下标可进行省略,当开始位置下标省略时默认为0,当结束位置下标省略时默认为字符串的长度。

下面给出对应的例子:

s = "Tom and Jerry and Spike and Tuffy"firstIndex = s.index("and")print("是否包含and字符串:", firstIndex > -1, ", 对应的坐标为:", firstIndex)index = s.index("and", 7)print("是否包含and字符串:", index > -1, ", 对应的坐标为:", index)lastIndex = s.rindex("and")print("是否包含and字符串:", lastIndex > -1, ", 对应的坐标为:", lastIndex)rightIndex= s.rindex("and", 7, -10)print("是否包含and字符串:", rightIndex > -1, ", 对应的坐标为:", rightIndex)notIndex = s.index("ands")print("是否包含and字符串:", notIndex > -1, ", 对应的坐标为:", notIndex)

执行结果如下:


count

count用于查询某个子串在字符串中出现的次数,其格式为:

字符串序列.count(⼦串, 开始位置下标, 结束位置下标)

需要说明的是,开始位置下标和结束位置下标均可进行省略,当开始位置下标省略时默认为0,当结束位置下标省略时默认为字符串的长度。

下面给出对应的例子:

s = "Tom and Jerry and Spike and Tuffy"print("and出现的次数为:", s.count("and"))print("下标从7到最后,and出现的次数为:", s.count("and", 7))print("ands出现的次数为 :", s.count("ands"))

执行结果如下:


4.2 修改

所谓修改就是通过函数对字符串中的数据进行修改。下面介绍一下常见的修改函数。

replace

replace的作用是将字符串中指定的子串替换为目标子串,其语法格式为:

字符串序列.replace(旧子串,新子串,替换次数)

对于替换次数而言,若未指定,则默认为该子串出现的次数;若指定次数小于出现次数,则替换指定次数;若指定次数大于出现次数,则替换实际出现的次数。

该方法与Java中的字符串的replace有相同的作用。当然,Java中的replace方法无法指定替换次数。

此外,替换操作并不会对原字符串有任何影响,其只会返回替换后的新字符串。

下面给出对应的示例:

s = "Tom and Jerry and Spike and Tuffy"# 将旧子串替换为新子串print("将s中的and替换为or后为:", s.replace("and", "or"))# 指定替换次数,小于该子串出现的次数print("将s中的and替换为or, 替换次数为2,替换后为:", s.replace("and", "or", 2))# 指定替换次数,大于该子串出现的次数print("将s中的and替换为or, 替换次数为4,替换后为:", s.replace("and", "or", 4))print("进行替换操作后,原字符串为:", s)

执行后结果如下:


split 和 join

split作用是根据指定的字符来分隔字符串,而Join的作用则是根据指定的字符串来将由多个字符串组成的字符序列进行合并。其语法格式为:

# spilt字符串序列.split(分割字符, num)# join 连接字符串.join(多个字符串组成的序列)

对于split的num而言,表示分隔字符出现的次数。当然,若未指定该次数,则默认为分隔符出现的次数;若指定的次数小于分隔符出现的次数,则会分割指定次数;若指定的次数大于分隔符出现的次数,则分割时按分隔符实际出现的次数进行分割。

spilt和join方法在Java中也有类似实现,当然,Java中的split方法无法指定分割次数。

下面为对应的例子:

s = "Tom and Jerry and Spike and Tuffy"# 根据and进行分割print("根据and进行分割后结果为:",s.split("and"))# 根据and进行分割,只分割2次print("根据and进行分割,分割次数为2,分割后结果为:",s.split("and", 2))# 根据and进行分割,只分割4次print("根据and进行分割,分割次数为2,分割后结果为:",s.split("and", 4))# 根据 " "进行分割print("根据空格进行分割后结果为:", s.split(" "))listStr = ["Tom", "Jerry", "Spike", "Tuffy"]# 用下划线进行连接print("用下划线进行连接后为:", "_".join(listStr))# 用...进行连接print("用...进行连接后为:", "...".join(listStr))

执行结果如下:


capitalize 和 title

capialize和title都可将字符串的首字母变为大写。区别在于,capitalize的作用是将整个字符串的首字母改为大写,而title则是将字符串的各单词的首字母变为大写,其语法格式为:

# capitalize字符串.capitalize()# title字符串.title()

需要说明的是,当字符串被capitalize方法转换后,除首字母保持大写外,其余字符均会变为小写。而title则是除各单词的首字母外,其余字母都会被改为小写。这两个方法暂未在Java中找到原生实现。

下面给出对应的示例:

s = "Tom and Jerry and Spike and Tuffy"print("执行capitalize方法后结果为:", s.capitalize())print("每个单词的首字母转换为大写后结果为:", s.title())s2 = "PutAndPoll"print("转换后结果为:", s2.title())

执行结果如下:


lower 和 upper

lower和uppder用于改变字符串的大小写。其中,lower是将字符串全部转为小写,而upper则是将字符串全部转为大写。当然,若为数字或其他非字母的数字,则会被忽略。其语法格式为:

# lower字符串.lower()# upper字符串.upper()

这两个方法在Java也有类似实现,lower类似于toLowerCase方法,而upper则类似于toUpperCase方法。

下面为对应的示例代码:

s = "Tom and Jerry and Spike and Tuffy"print("全部转换为小写后:", s.lower())print("全部转换为大写后:", s.upper())

执行结果如下:


lstrip、rstrip和strip

这三个函数都可删除字符串的空白字符,区别在于,lstrip是删除字符串左侧的空白字符,rstrip是删除字符串右侧的空白字符,而strip是将字符串两侧的空白字符都进行删除。其语法格式为:

# lstrip字符串.lstrip()# rstrip字符串.rstrip()# strip字符串.strip()

对于这三个方法来说,Java只实现了类似strip方法,也就是trim方法。

下面是对应的示例代码:

s = " Tom and Jerry and Spike and Tuffy "print("删除左侧的空白字符后为:", s.lstrip(), ", 长度为:", len(s.lstrip()))print("删除右侧的空白字符后为:", s.rstrip(), ", 长度为:", len(s.rstrip()))print("删除两侧的空白字符后为:", s.strip(), ", 长度为:", len(s.strip()))

执行结果如下:


ljust、rjust和center

这三个方法实现对效果类似于对齐,ljust是左对齐,rjust是右对齐,而center则是中心对齐。当然,若原字符串的长度小于指定长度时,会使用指定的字符串进行填充;若原字符串长度大于指定长度,则自己返回原字符串。其语法格式为:

# ljust字符串.ljust(长度,填充字符)# rjust字符串.rjust(长度,填充字符)# center字符串.center(长度,填充字符)

需要说明的是,填充字符串只能是单个字符,若为多个字符,则会抛出异常。

下面给出对应的示例代码:

s = "hello"# 默认为空格机械能填充print("左对齐并填充到10位:", s.ljust(10))# 使用指定字符进行填充print("左对齐并填充到10位:", s.ljust(10, "."))# 默认为空格机械能填充print("右对齐并填充到10位:", s.rjust(10))# 使用指定字符进行填充print("右对齐并填充到10位:", s.rjust(10, "."))# 默认为空格机械能填充print("中心对齐并填充到10位:", s.center(10))# 使用指定字符进行填充print("中心对齐并填充到10位:", s.center(10, "."))

执行结果如下:


4.3 判断

所谓判断就是通过函数来确定该字符串是否符合特定条件,其返回结果为布尔值。下面简单介绍一下常见的判断类函数。

startswith 和 endswith

startwith用于判断该字符串是否以指定的子串开头,而endswith则用于判断该字符串是否以指定的子串结尾。其语法格式为:

# startswith字符串序列.startswith(⼦串, 开始位置下标, 结束位置下标)# endswith字符串序列.endswith(⼦串, 开始位置下标, 结束位置下标)

这两个方法在Java中也有对应的实现,startswith对应startsWith,endswith对应endsWith。区别在于,Java中的实现不支持设置结束位置坐标。

下面为对应的示例代码:

s = "hello world, are you ok"print("该字符串是否以hello打头:", s.startswith("hello"))print("该字符串从下标5开始到结尾,是否存在以hello打头的子串:", s.startswith("hello", 5))print("该字符串是否以ok结尾:", s.endswith("ok"))print("该字符串从开始到倒数第三的下标的子串是否以ok结尾:", s.endswith("ok", 0, -3))

执行结果如下:


isalpha、isdigit、isalnum和isspace

这四个函数用于对字符串是否为字母或数字进行判断。其中,isalpha用于判断该字符串非空且全部为字母,isdigit用于判断该字符串是否非空且全部为数字,isalnum用于判断该字符串是否非空且全部为数字或字母,ispace则用于判断该字符串是否全部为空白字符。

其语法格式为:

# isalpha字符串.islapha()# isdigit字符串.isdigit()# isalnum字符串.isalnum()# isspace字符串.isspace()

下面给出对应的示例:

s1 = "hello"s2 = "12345"s3 = "hello12345"s4 = "hello12345_"print("s1是否非空且全部为字母:", s1.isalpha())print("s2是否非空且全部为字母:", s2.isalpha())print("s3是否非空且全部为字母:", s3.isalpha())print("s4是否非空且全部为字母:", s4.isalpha())print("s1是否非空且全部为数字:", s1.isdigit())print("s2是否非空且全部为数字:", s2.isdigit())print("s3是否非空且全部为数字:", s3.isdigit())print("s4是否非空且全部为数字:", s4.isdigit())print("s1是否非空且全部为字母或数字:", s1.isalnum())print("s2是否非空且全部为字母或数字:", s2.isalnum())print("s3是否非空且全部为字母或数字:", s3.isalnum())print("s4是否非空且全部为字母或数字:", s4.isalnum())s5 = "a b c d "s6 = " "print("s5是否全部为非空字符:", s5.isspace())print("s6是否全部为非空字符:", s6.isspace())

执行结果如下:


仔细观察,可以发现Python中判断是否数字的函数除isdigit外,还有两个,分别是:isnumeric和isdecimal。这三者的区别在于,isdigit判断的是是否为数字字符,其认为合法的字符有:Unicode数字和数字,但不包括罗马数字、汉字数字及小数;isnumeric判断的是是否为数值字符,包括:Unicode数字、数字、汉字数字,但却不包括小数和罗马数字,当然,也有说包含罗马数字的,但我尝试后发现并不包含;isdecimal则判断的是是否为十进制数字字符,包括:Unicode数字、数字,但不包括罗马数字、汉字数字和小数。

下面给出对应的示例:

s1 = "123"s2 = "3.14"s3 = "IV"s4 = "十贰"print(s1, "是否为digit:", s1.isdigit())print(s2, "是否为digit:", s2.isdigit())print(s3, "是否为digit:", s3.isdigit())print(s4, "是否为digit:", s4.isdigit())print(s1, "是否为decimal:", s1.isdecimal())print(s2, "是否为decimal:", s2.isdecimal())print(s3, "是否为decimal:", s3.isdecimal())print(s4, "是否为decimal:", s4.isdecimal())print(s1, "是否为numerical:", s1.isnumeric())print(s2, "是否为numerical:", s2.isnumeric())print(s3, "是否为numerical:", s3.isnumeric())print(s4, "是否为numerical:", s4.isnumeric())print("iii")

执行结果如下:


isupper、islower和istitle

isupper用于判断字符串是否全部为大写,islower用于判断字符串是否全部为小写,istitle则用于判断字符串的各单词的首字母是否大写。下面为对应的语法格式:

# isuppper字符串.isupper# islower字符串.islower# istitle字符串.istitle

下面为对应的例子:

s1 = "Tom and Jerry"s2 = "this is a boy"s3 = "GOOD"s4 = "Oh, My God"print(s1, "是否全部为小写: ", s1.islower())print(s2, "是否全部为小写: ", s2.islower())print(s3, "是否全部为小写: ", s3.islower())print(s4, "是否全部为小写: ", s4.islower())print(s1, "是否全部为大写: ", s1.isupper())print(s2, "是否全部为大写: ", s2.isupper())print(s3, "是否全部为大写: ", s3.isupper())print(s4, "是否全部为大写: ", s4.isupper())print(s1, "是否各单词为首字母大写: ", s1.istitle())print(s2, "是否各单词为首字母大写: ", s2.istitle())print(s3, "是否各单词为首字母大写: ", s3.istitle())print(s4, "是否各单词为首字母大写: ", s4.istitle())

执行结果如下:


  • 连花清瘟胶囊作用是什么(连花清瘟胶囊功效有哪些)
  • 2024-11-06连花清瘟胶囊功效有哪些每到季节变换的时候,很多人都会因为天气的变化患上了感冒连花清瘟胶囊属于是一种中药,在该药中含有炒苦杏仁、鱼腥草、甘草和薄荷脑等该药在治疗感冒时有明显的效果,但是心脏病患者服用该药的时候就需要谨慎,最好。
  • 隐形眼镜年抛和半年抛的区别(隐形眼镜不同抛期的优缺点)
  • 2024-11-06隐形眼镜不同抛期的优缺点季抛/半年抛/年抛:长周期佩戴,性价比高优点:(1)性价比非常高,长周期的镜片价格比短周期的要便宜很多,如果经常戴美瞳可以选择(2)镜片寿命长,相对较硬的镜片材质便于长期存放缺点:(1)护理步骤比较繁。
  • 王凯演的宋朝古装剧(王凯演的宋仁宗历史上究竟有多难)
  • 2024-11-06王凯演的宋仁宗历史上究竟有多难网文大IP正午出品芒果平台播出的《清平乐》,开播已经整整一周,口碑爆棚,每次更新,都会引发一系列热点对于磕帝后cp的影迷来说,这剧看到现在,王凯饰演的宋仁宗太令人心疼了,甚至还将历史上的这位皇帝带上了。
  • 阴阳师怎么做体力消耗最少(阴阳师丰年来临)
  • 2024-11-06阴阳师丰年来临俗话说,玩阴阳师最怕的是什么?活动来了,体力没了,望着奖励空兴叹那有什么在活动期间积攒体力的办法吗?我们就来简单介绍几种:突破:突破绝对是肝帝提升自己的良好手段之一,每场固定获得荣誉的同时,有几率获得。
  • 人体组织是什么意思(人体组织的含义)
  • 2024-11-06人体组织的含义具有相同功能的细胞集合在一起形成的细胞团就叫做组织上皮组织:由上皮细胞构成,细胞排列紧密,具有保护、分泌等作用结缔组织:种类较多,细胞间质发达,医学|教育网编辑整理分布广泛,具有支持、连接、保护、营养。
  • 顺丰空运的成本(顺丰空运业务量创新高)
  • 2024-11-06顺丰空运业务量创新高据物流一图粉丝爆料,顺丰以空运为主的时效件业务发展迅速,近日或已突破1200万单!超过12月时效件业务的120%!并占到了全部快递业务量的6成左右!其实顺丰空运业务激增,除与疫情期间陆运交通管制下空运。
  • 驴友探险的正确方法(长阳户外驴友体验)
  • 2024-11-06长阳户外驴友体验再拉一篇2015年的户外叙事,我们继续叙旧啊!2015年5月3日,在五一黄金小长假最后一天,长阳户外一行18人结队前往长阳秭归交界处的三点水在美丽的清江河畔,我们相约7点出发!当人们还在旅游拥挤变疲惫。
  • 纯东北话方言大全(东北方言诙谐幽默)
  • 2024-11-06东北方言诙谐幽默东北人以热情开朗豪爽而得名,然而现在个多的人则认为东北人还比较幽默诙谐,东北也出了非常多的谐星笑星,被全国人民喜欢今天就给大家这些谐星和笑星包袱里经常出现的八大犊子和四大神兽先说八大犊子滚。
  • 柯以敏点评选手扭动身子(因戒指门害人害已)
  • 2024-11-06因戒指门害人害已毒舌还是没有礼貌2016年柯以敏的一句话,直接将停播了10年的《超级女声》,推向了舆论的顶端柯以敏担任《超级女声》评委海选现场,一位刚满18岁的女选手,因为当天突然有些重感冒,所以在演唱前特意将自己的。
  • 世界上濒临灭绝的四种动物(被许多人认为已经灭绝)
  • 2024-11-06被许多人认为已经灭绝一直以来,人们总是为了灭绝的生物感到惋惜,也在不断的努力保护那些濒临灭绝的生物但多年来,世界各地都有关于一些灭绝生物重现人间的事情发现但是,有一些所谓的目击事件是非常不可靠的从传说中失踪已久的恐龙到丛。