python字符串的四种表达(Python字符串类型介绍)
python字符串的四种表达(Python字符串类型介绍)
2024-11-22 05:23:18  作者:学会作弊  网址:https://m.xinb2b.cn/know/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())

执行结果如下:


  • lol中最难缠的英雄(本周LOL免费英雄最佳组合推荐)
  • 2024-11-22本周LOL免费英雄最佳组合推荐最新一周的LOL免费英雄已经上线,本周的周免英雄中C位比较多,其次是打野,下面我们就结合本周的这些免费英雄,给大家推荐一组比较强力的组合阵容阵容特点这是一套中上双法坦的阵容体系,下路蓝EZ与布隆的双减。
  • 恩施玉露是什么茶(恩施玉露茶资料)
  • 2024-11-22恩施玉露茶资料恩施玉露具有风格独特的品质特色,外形看起来如松针一般,条索紧细圆直,颜色翠绿且泛有光泽,白毫显露;泡水后,茶汤清澈明亮,香气清新高长且沁人心脾,入口后滋味甘醇鲜爽,齿间余香久久不散相传在清朝康熙年间,。
  • 瘦大腿的方法1天见效(怎么瘦大腿快速有效)
  • 2024-11-22怎么瘦大腿快速有效非常见效的瑜伽动作,背部挺直站立吸气,双掌放于头上,单腿提起腿掌贴于大腿侧,左右腿各做10下坐在地板上,向内弯曲一条腿,先吸气,身体向伸直的腿倾前,呼气后坐直,左右腿各做5次多做有氧运动如跑步和游泳,。
  • 海贼王克洛克达尔最新消息(海贼王最可怕的谣言)
  • 2024-11-22海贼王最可怕的谣言早在伊万科夫出现之前就有人猜测克洛克达尔是女人,一个原因是克洛克达尔手上戴满戒指,唯独无名指上没戴,这个位置是戴结婚戒指的阿拉巴斯坦有一头叫睫毛的骆驼只驼女人,但它却驼过老沙巴洛克工作社的命名,一男一。
  • 林徽因和徐志摩到底有没有恋爱过(林徽因与徐志摩的凄美爱情)
  • 2024-11-22林徽因与徐志摩的凄美爱情民国短短数十年间,论才子佳人最著名者,非徐志摩与林徽因莫属徐志摩,民国诗坛上最耀眼的新星,却行为荒诞,性气乖张,荒唐的决断铸就悲惨的结局,他用一生的哀怨,写就一首凄婉的诗歌;林徽因,集美丽和智慧于一身。
  • 新款日产suv即将上市(日产全新SUV海外发布)
  • 2024-11-22日产全新SUV海外发布众所周知,近几年国内汽车市场的发展非常火爆,庞大的市场需求量让一些品牌赚的是盆满钵满,尤其是大众、丰田、本田等主流合资品牌,成为了国内汽车市场最大的赢家,当然,像吉利、长城、长安等自主品牌的表现也很抢。
  • 如何提高沟通的技巧(如何有效提高沟通技巧)
  • 2024-11-22如何有效提高沟通技巧要去充分了解清楚信息,在沟通前的准备工作,针对要沟通的事情提前准备好,以便在沟通中有内容可以阐述,同时要注意沟通的对象和事情一定要尽可能熟知,千万不要出现沟通时的信息出入,这样类似的信息不对称,那都是。
  • 库钓打窝留鱼技巧(遭遇鱼情差鱼层乱鱼口差)
  • 2024-11-22遭遇鱼情差鱼层乱鱼口差​说起打行程这种钓法,精通者觉得用起来舒服,属于主动找口的钓法,而用不好的钓友,会觉得这种钓法,最糟糕的地方,太容易招惹小鱼,而且鱼口全然没有章法,纯属拼人品,人品到位,那自不用多说,人品不行,尽是小。
  • 李隆基悲惨晚年 此人是李隆基原配
  • 2024-11-22李隆基悲惨晚年 此人是李隆基原配在电视连续剧《宫心计2·深宫计》的中,李隆基的原配夫人叫王蓁其实是不对的,历史上真实的李隆基原配夫人也姓王,名字记载不详有说叫王有容,又有说这个名字不对(王蓁剧照)历史上真实王氏的故事,其精彩程度并不。
  • 北京市文化发展规划(文化创新扮靓都市空间)
  • 2024-11-22文化创新扮靓都市空间7月25日,首届北京文化论坛开幕北京文化论坛的发展方向是打造文化领域的全国性品牌论坛作为全国文化中心,5年来,北京围绕“一核一城三带两区”总体框架,深化全国文化中心建设,文化事业和产业蓬勃发展,文化软。
  • 加湿器里的水是否有毒(加湿器使用不当)
  • 2024-11-22加湿器使用不当长期呆在空调房里总是感觉到一定不适而这个时候有一样东西就出场了对,就是加湿器是不是很熟悉?很多人担心加湿器里面滋生细菌喜欢在加湿器里加“杀菌剂”等物质还有精致的小姐姐们会在加湿器里加香薰他们以为这是在。
  • 足球鞋该怎么选购(足球鞋选购完全指南)
  • 2024-11-22足球鞋选购完全指南每一个足球爱好者总是不时地面对一个问题:如何在商店里挑选一双好的新球鞋市场上实在有太多让人眼花缭乱的选择,想要从中挑选一双称脚的战靴总是不那么容易的事情小编搜集了网络资料并加工改写,整理出了这篇战靴选。