python字符串的四种表达(Python字符串类型介绍)
python字符串的四种表达(Python字符串类型介绍)
2024-09-28 02:34:26  作者:学会作弊  网址:https://m.xinb2b.cn/sport/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-09-28怎么辨别白茶的好坏 即可鉴别白茶好坏优劣本文由白茶家族原创撰写,未经允许,不许转载!文|白妹子01今天是周一,对于还在上班的茶友们来说,每周一都是一个新的开始新的开始里,总想赋予一些新的变化在里面随着越来越多新茶友的加入,小白忽然意识到自己。
  • 塑料水杯什么材质的比较安全(关于塑料水杯材质介绍)
  • 2024-09-28关于塑料水杯材质介绍塑料水杯使用PP材质的比较安全pp材质是聚丙烯,聚丙烯为无毒、无臭、无味的乳白色高结晶的聚合物,密度只有0.90-0.91g/cm3,是目前所有塑料中最轻的品种之一pp材质对水特别稳定,在水中的吸水率。
  • 普通话读错4个字能不能过(逼死普通话老师)
  • 2024-09-28逼死普通话老师大家好!我是苦13人民教师公子,作为一名一级乙等的职业学校普通话教师,我盘点了一下念错率zhuì高(颜如晶上身)的5个汉字,有些字甚至连主持人都会念错!简直忍无可忍啊!!来,大家看看,这些字你都念对了。
  • 仓颉造字为何鬼要哭(许慎仓颉为何造)
  • 2024-09-28许慎仓颉为何造【仓颉造字•亚】许慎:仓颉为何造“亚”字?【本义】“亚”的本义为正视的族徽和俯视的祭坛形【解读】事有求全之毁,故人生处世,当“行”求“冠军”而“心”合“亚军”此心即彼心,若心以“冠军”自居,则日常之中。
  • 孔子八句话经典语录(毁三观孔子的这10句话)
  • 2024-09-28毁三观孔子的这10句话一直以来,孔子这个有志青年的很多名言因名气过盛、解读过多而常为人误解,甚至成为颠扑不破的真理然而这些名言的真相却会让你大吃一惊唯女子与小人为难养也误解:这句话出自《论语·阳货》,一般在感情上受过伤害的。
  • 桃符是什么节日的象征(到底有什么说法)
  • 2024-09-28到底有什么说法桃木剑、桃木如意、桃木挂件、寿桃酒、桃花茶……走进桃乡肥城的中国桃文化博物馆,琳琅满目的桃文化展品充分诠释了何为“居不可无桃”中国桃文化源远流长,渗透到生活的方方面面,春节自然也少不了和桃有关的习俗“。
  • 秭归夏橙什么时候成熟(秭归夏橙每年的成熟时间)
  • 2024-09-28秭归夏橙每年的成熟时间秭归夏橙每年的5月份左右左右成熟秭归夏橙一般在初夏成熟,也就是5月份左右,最长留树时间可长达16个月秭归夏橙的存在,改变了中国夏季水果一橙难寻的局面,它以良好的品质和水果淡季的呈现,成为夏季水果的橙中。
  • 鹿鼎记张一山浮夸演技(鹿鼎记翻车遭群嘲)
  • 2024-09-28鹿鼎记翻车遭群嘲新版《鹿鼎记》在众人群嘲下获得新称谓——猴戏质量全线崩塌,但最抢眼的,无疑还是张一山演技前两天导演回应争议了:“论演技,在迄今为止所有版本的韦小宝序列中,张一山也是顶级”△资料来源:微博@新浪娱乐不说。
  • 关于爱情经典句子的说说(关于爱情唯美的说说)
  • 2024-09-28关于爱情唯美的说说1、一个人就算再好,但不愿陪你走下去,那他就是过客;一个人再有缺点,但能处处忍让你,陪你到最后,就是终点2、一个人最幸福的时刻,就是找到了对的人,他宠着你,纵容你的习惯,并爱着你的一切3、没有完全合适。
  • autoform分析完成后怎么查看(AutoSave自动保存)
  • 2024-09-28AutoSave自动保存来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营通过分析几个官方设计案例:MacOSXLion,Microsoft,WordPress,Rhino,和几个亲自体验的产品。