4.Python的字符串介绍

目录

1.字符串介绍

2.字符串的输入与输出

3.访问字符串中的值

4.字符串内建函数


1.字符串介绍

Python中字符串有三种表现方式:

(1)使用单引号包含字符

name1='hello'

(2)使用双引号包含字符

str1="hello1"

str2="I'm Tom1"

(3)使用三引号(三对单引号或者三对双引号)

str3='''hello'''

str4="""I

am Tom"""

注意:三引号可以包含换行符

运行结果:

4.Python的字符串介绍_第1张图片

 

转义字符

在需要在字符中使用特殊字符时,python 用反斜杠 \ 转义字符。如下表:

转义字符

描述

\(在行尾时)

续行符

\\

反斜杠符号

\'

单引号

\"

双引号

\a

响铃

\b

退格(Backspace)

\e

转义

\000

\n

换行

\v

纵向制表符

\t

横向制表符

\r

回车

\f

换页

\oyy

八进制数,yy代表的字符,例如:\o12代表换行

\xyy

十六进制数,yy代表的字符,例如:\x0a代表换行

\other

其它的字符以普通格式输出

 

2.字符串的输入与输出

字符串输出

4.Python的字符串介绍_第2张图片

 

字符串输出

4.Python的字符串介绍_第3张图片

 

4.Python的字符串介绍_第4张图片

运行结果

4.Python的字符串介绍_第5张图片

不管输入的是什么,输出的类型都是String类型

 字符串格式化符号:

    符   号

描述

      %c

 格式化字符及其ASCII码

      %s

 格式化字符串

      %d

 格式化整数

      %u

 格式化无符号整型

      %o

 格式化无符号八进制数

      %x

 格式化无符号十六进制数

      %X

 格式化无符号十六进制数(大写)

      %f

 格式化浮点数字,可指定小数点后的精度

      %e

 用科学计数法格式化浮点数

      %E

 作用同%e,用科学计数法格式化浮点数

      %g

 %f和%e的简写

      %G

 %F 和 %E 的简写

      %p

 用十六进制数格式化变量的地址

 

3.访问字符串中的值

1.字符串的存储方式

给出下标即可,第一个元素的下标是0,最后一个的下标既可以是(长度-1)也可以是-1。

索引可以分为正索引和负索引。

假设有个字符串“01234567”,那么它对应的索引如下图所示:

4.Python的字符串介绍_第6张图片

 

如:

运行结果:

2.使用切片截取字符串

格式:<字符串>[<起始位置>:<终止位置>:<步长>]

步长为1,每次走一步;步长为2,每次走两步,中间隔一位。得到从<起始位置>开始,间隔为<步长>,到<终止位置>前一个字符结束的字符串。也就是说是一个左闭右开区间。

起始位置可以省略,表示起始位置为0,从第一个开始。<终止位置>可以省略,表示终止位置为末尾,到最后一个为止。步长也可以省略,表示步长为1。

步长可以为负。

字符串第一个元素的索引是0,字符串最后一个元素的所以是len(str)-1或者是-1。

之后的可以以此类推。

4.Python的字符串介绍_第7张图片

例:

运行结果

例:

4.Python的字符串介绍_第8张图片

运行结果

例:

 

4.Python的字符串介绍_第9张图片

运行结果

 

普通切片操作

temp="ABCDEFGHIJKLMNOPQRSTUVWXYZ"

#从索引为0的位置开始输出,直到输出索引为9的位置的数据(10不包括)

#步长默认为1

print(temp[0:10])  #ABCDEFGHIJ

print(temp[0:10:2])

#开始我以为会输出ADG……形式的数据,但结果是ACEGI

#原来步长为2,中间只隔一个……

输出从第一个到倒数第N个数

同理也可推出第M个数到倒数第N个数。

例如:输出不包含最后两个元素的字符串切片。

temp="ABCDEFGHIJKLMNOPQRSTUVWXYZ"

print(temp[0:-2])

#ABCDEFGHIJKLMNOPQRSTUVWX

#最末尾两个数没有输出,步长是1已经省略

#亦可写成

print(temp[:-2])  #ABCDEFGHIJKLMNOPQRSTUVWX

#完整形式是print(temp[0:-2:1])

输出末尾的N个数

例如从倒数第2个数开始输出

temp="ABCDEFGHIJKLMNOPQRSTUVWXYZ"

print(temp[-2:])  #YZ

#完整形式是print(temp[-2:27:1])

全部逆序输出 


temp="ABCDEFGHIJKLMNOPQRSTUVWXYZ"

print(temp[::-1])

#ZYXWVUTSRQPONMLKJIHGFEDCBA

4.Python的字符串介绍_第10张图片

 

运行结果

4.Python的字符串介绍_第11张图片

 

循环迭代输出

字符串作为可迭代对象,自然可以迭代循环输出。

str = "ABCDEFG"

for s in str:

    print(s, end = " ")

#A B C D E F G

str = "ABCDEFG"

for index, item in enumerate(str):

    print(item, end =" ")

#A B C D E F G

 

4.字符串内建函数

Python 的字符串常用内建函数如下:

序号

方法及描述

1

capitalize()

将字符串的第一个字符转换为大写

2

center(width, fillchar)

返回一个指定的宽度 width 居中的字符串,fillchar 为填充的字符,默认为空格。

3

count(str, beg= 0,end=len(string))

返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数

4

bytes.decode(encoding="utf-8", errors="strict")

Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。

5

encode(encoding='UTF-8',errors='strict')

以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'

6

endswith(suffix, beg=0, end=len(string))

检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.

7

expandtabs(tabsize=8)

把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。

8

find(str, beg=0 end=len(string))

检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1

9

index(str, beg=0, end=len(string))

跟find()方法一样,只不过如果str不在字符串中会报一个异常.

10

isalnum()

如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False

11

isalpha()

如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False

12

isdigit()

如果字符串只包含数字则返回 True 否则返回 False..

13

islower()

如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False

14

isnumeric()

如果字符串中只包含数字字符,则返回 True,否则返回 False

15

isspace()

如果字符串中只包含空白,则返回 True,否则返回 False.

16

istitle()

如果字符串是标题化的(见 title())则返回 True,否则返回 False

17

isupper()

如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False

18

join(seq)

以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串

19

len(string)

返回字符串长度

20

ljust(width[, fillchar])

返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。

21

lower()

转换字符串中所有大写字符为小写.

22

lstrip()

截掉字符串左边的空格或指定字符。

23

maketrans()

创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。

24

max(str)

返回字符串 str 中最大的字母。

25

min(str)

返回字符串 str 中最小的字母。

26

replace(old, new [, max])

把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。

27

rfind(str, beg=0,end=len(string))

类似于 find()函数,不过是从右边开始查找.

28

rindex( str, beg=0, end=len(string))

类似于 index(),不过是从右边开始.

29

rjust(width,[, fillchar])

返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串

30

rstrip()

删除字符串字符串末尾的空格.

31

split(str="", num=string.count(str))

num=string.count(str)) 以 str 为分隔符截取字符串,如果 num 有指定值,则仅截取 num 个子字符串

32

splitlines([keepends])

按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。

33

startswith(str, beg=0,end=len(string))

检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。

34

strip([chars])

在字符串上执行 lstrip()和 rstrip()

35

swapcase()

将字符串中大写转换为小写,小写转换为大写

36

title()

返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())

37

translate(table, deletechars="")

根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中

38

upper()

转换字符串中的小写字母为大写

39

zfill (width)

返回长度为 width 的字符串,原字符串右对齐,前面填充0

40

isdecimal()

检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。

 

 

4.Python的字符串介绍_第12张图片

 

4.Python的字符串介绍_第13张图片

 

4.Python的字符串介绍_第14张图片

 

4.Python的字符串介绍_第15张图片

 

4.Python的字符串介绍_第16张图片

 

4.Python的字符串介绍_第17张图片

 

4.Python的字符串介绍_第18张图片

 

4.Python的字符串介绍_第19张图片

 

4.Python的字符串介绍_第20张图片

 

4.Python的字符串介绍_第21张图片

 

4.Python的字符串介绍_第22张图片

 

4.Python的字符串介绍_第23张图片

 

4.Python的字符串介绍_第24张图片

 

4.Python的字符串介绍_第25张图片

 

4.Python的字符串介绍_第26张图片

 

-----------------------------------------------------------------------------------------------------

string = 'XXX'

  • string.capitalize() # 把字符串的第一个字符大写
  • string.center(width) # 返回一个原字符串居中,并使用空格填充至长度 width 的新字符串
  • string.count(str, beg=0, end=len(string)) # 返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数
  • string.decode(encoding='UTF-8', errors='strict') # 以 encoding 指定的编码格式解码 string,如果出错默认报一个 ValueError 的 异 常 , 除 非 errors 指 定 的 是 'ignore' 或 者'replace'
  • string.encode(encoding='UTF-8', errors='strict') # 以 encoding 指定的编码格式编码 string,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'
  • string.endswith(obj, beg=0, end=len(string)) # 检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.
  • string.expandtabs(tabsize=8) # 把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8。
  • string.find(str, beg=0, end=len(string)) # 检测 str 是否包含在 string 中,如果 beg 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1
  • string.index(str, beg=0, end=len(string)) # 跟find()方法一样,只不过如果str不在 string中会报一个异常.
  • string.isalnum() # 如果 string 至少有一个字符并且所有字符都是字母或数字则返回 True,否则返回 False
  • string.isalpha() # 如果 string 至少有一个字符并且所有字符都是字母则返回 True,否则返回 False
  • string.isdecimal() # 如果 string 只包含十进制数字则返回 True 否则返回 False.
  • string.isdigit() # 如果 string 只包含数字则返回 True 否则返回 False.
  • string.islower() # 如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False
  • string.isnumeric() # 如果 string 中只包含数字字符,则返回 True,否则返回 False
  • string.isspace() # 如果 string 中只包含空格,则返回 True,否则返回 False.
  • string.istitle() # 如果 string 是标题化的(见 title())则返回 True,否则返回 False
  • string.isupper() # 如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
  • string.join(seq) # 以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串
  • string.ljust(width) # 返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串
  • string.lower() # 转换 string 中所有大写字符为小写.
  • string.lstrip() # 截掉 string 左边的空格
  • string.maketrans(intab, outtab]) # maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
  • max(str) # 返回字符串 str 中最大的字母。
  • min(str) # 返回字符串 str 中最小的字母。
  • string.partition(str) # 有点像 find()和 split()的结合体,从 str 出现的第一个位置起,把 字 符 串 string 分 成 一 个 3 元 素 的 元 组 (string_pre_str,str,string_post_str),如果 string 中不包含str 则 string_pre_str == string.
  • string.replace(str1, str2, num=string.count(str1)) # 把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次.
  • string.rfind(str, beg=0,end=len(string)) # 类似于 find()函数,不过是从右边开始查找.
  • string.rindex( str, beg=0,end=len(string)) # 类似于 index(),不过是从右边开始.
  • string.rjust(width) # 返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串
  • string.rpartition(str) # 类似于 partition()函数,不过是从右边开始查找.
  • string.rstrip() # 删除 string 字符串末尾的空格.
  • string.split(str="", num=string.count(str)) # 以 str 为分隔符切片 string,如果 num有指定值,则仅分隔 num 个子字符串
  • string.splitlines(num=string.count('\n')) # 按照行分隔,返回一个包含各行作为元素的列表,如果 num 指定则仅切片 num 个行.
  • string.startswith(obj, beg=0,end=len(string)) # 检查字符串是否是以 obj 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查.
  • string.strip([obj]) # 在 string 上执行 lstrip()和 rstrip()
  • string.swapcase() # 翻转 string 中的大小写
  • string.title() # 返回"标题化"的 string,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())
  • string.translate(str, del="") # 根据 str 给出的表(包含 256 个字符)转换 string 的字符,要过滤掉的字符放到 del 参数中
  • string.upper() # 转换 string 中的小写字母为大写
  • string.zfill(width) # 返回长度为 width 的字符串,原字符串 string 右对齐,前面填充0
  • string.isdecimal() # isdecimal()方法检查字符串是否只包含十进制字符。这种方法只存在于unicode对象。

 

 

 

 

 

 

你可能感兴趣的:(Python,python)