python3笔记九:python数据类型-String字符串

一:学习内容

  • 字符串概念
  • 字符串运算
  • 字符串函数:eval()、len()、lower()、upper()、swapcase()、capitalize()、title()、center()、ljust()、rjust()、zfill()、count()、find()、rfind()、index()、rindex()、lstrip()、rstrip()、strip()、ord()、chr()、split()、splitlines()、join()、max()、min()、replace()、startswith()、endswith()、encode()、decode()、isalpha()、isalnum()、isdigit()、isupper()、islower()、istitle()、isspace()

 

二:字符串概念

1. 字符串是以单引号或双引号括起来的任意文本
'abc'
"abc"

 

2.创建字符串
str1 = "learn python3!"

 

三:字符串运算

1. 字符串连接

str2 = "hello "
str3 = "world!"
str4 = str2 + str3
print("str4 =", str4)

 

2.输出重复字符串
str5 = "good"
str6 = str5 * 3
print("str6 =", str6)

 

3.访问字符串中的某一个字符
#通过索引下标查找字符,索引从0开始
#字符串名[下标]
str7 = "test is a good girl!"
print(str7[1])


str7[1] = "a" #字符串不可变
print(str7)

 

4.截取字符串中的一部分

#字符串名[开始下标:结束下标],属于闭开区间
str7 = "test is a good girl!"
str8 = str7[7:16]
print("str8 =", str8)
#从头截取到给定下标之前,不包括结束下标
str9 = str7[0:6]  #str7[:6]
print("str9 =", str9)
#从给定下标处开始截取到结尾
str10 = str7[17:]  #str7[:6]
print("str10 =", str10)

 

5.判断给出的字符串是否存在

str11 = "test is a good girl"
print("good" in str11)
print("good1" not in str11)

 

6.格式化输出
# %d %s %f 占位符
print("test is a good girl")
num = 10
print("num =", num)
print("num = %d" % num)


str12 = "test"
f = 10.1234567890
#%.2f精确到小数点后3位,会四舍五入
print("num = %d, str12 = %s, f = %.2f" % (num, str12, f))

 

四:字符串函数

1. eval(str)函数

功能:将字符串str当成有效的表达式来求值并返回计算结果

num1 = eval("123")
print("num1的值为:%d" % num1)
print(type(num1))


print(eval("-123"))
print(eval("12-3"))


print(eval("12a3"))

 

2.len(str)函数

功能:返回字符串的长度(字符个数,不是字节数,一个中文是一个字符)

print(len("测试"))

 

3.str.lower()函数

功能:转换字符串中大写字母为小写字母,原字符串不变

str13 = "TEST is A GooD GirL"
print(str13.lower())
print(str13)

 

4.str.upper()函数

功能:转换字符串中小写字母为大写字母,原字符串不变

str14 = "TEST is A GooD GirL!测试"
print(str14.upper())
print(str14)

 

5.str.swapcase()

功能:转换字符串中小写字母为大写字母,大写变小写,原字符串不变

str15 = "Test Is A Good Girl!测试"
print(str15.swapcase())

 

6.str.capitalize()

功能:首字母大写,其他小写,原字符串不变

str16 = "test is a good girl!测试"
print(str16.capitalize())

 

7.str.title()

功能:每个单词的首字母大写,其他小写,原字符串不变

str17 = "test is a good girl"
print(str17.title())

 

8.str.center(width[,fillchar])

功能:返回一个指定宽度的居中字符串,fillchar为填充的字符串,默认是空格填充

str18 = "test is a good girl"
print(str18.center(40,"*"))

 

9.str.ljust(width[,fillchar])

功能:返回一个指定宽度的左对齐字符串,fillchar为填充的字符串,默认是空格填充

str19 = "test is a good girl"
print(str19.ljust(40,"*"))

 

10.str.rjust(width[,fillchar])

功能:返回一个指定宽度的右对齐字符串,fillchar为填充的字符串,默认是空格填充

str19 = "test is a good girl"
print(str19.rjust(40,"*"))

 

11.str.zfill(width)

功能:返回一个指定宽度的字符串,左侧用0填充

str20 = "test is a good girl"
print(str20.zfill(40))

 

12.str.count(s[,start][,end])

功能:返回str字符串中s字符串出现的次数,可以指定一个范围,不指定范围默认从头到尾

str21 = "test is a very very good girl"
print(str21.count("very"))
print(str21.count("very",14,len(str21)))

 

13.str.find(s[,start][,end])

功能:从左向右检测s字符串是否包含在字符串中,可以指定范围,不指定范围默认从头到尾

返回的结果是s字符串第一次出现的开始下标,没有则返回-1

str22 = "test is a very very good girl"
print(str22.find("very"))
print(str22.find("very",14,len(str22)))
print(str22.find("ddd"))   #返回-1

 

14.str.rfind(s[,start][,end])

功能:从右向左检测s字符串是否包含在字符串中,可以指定范围,不指定范围默认从头到尾
返回的结果是s字符串第一次出现的开始下标,没有则返回-1

str23 = "test is a very very good girl"
print(str23.rfind("very"))
print(str23.rfind("very",0,15))
print(str23.rfind("ddd"))   #返回-1

 

15.str.index(s[,start][,end])
跟find()一样,只不过如果s不存在的时候会报异常

功能:从左向右检测s字符串是否包含在字符串中,可以指定范围,不指定范围默认从头到尾
返回的结果是s字符串第一次出现的开始下标

str24 = "test is a very very good girl"
print(str24.index("very"))
print(str24.index("very",0,15))
print(str24.index("ddd"))   #找不到会报错,报错

 

16.str.rindex(s[,start][,end])

跟rfind()一样,只不过如果s不存在的时候会报异常

功能:从右向左检测s字符串是否包含在字符串中,可以指定范围,不指定范围默认从头到尾
返回的结果是s字符串第一次出现的开始下标

str25 = "test is a very very good girl"
print(str25.rindex("very"))
print(str25.rindex("very",0,15))
print(str25.rindex("ddd"))   #报错

 

17.str.lstrip(s)

功能:截取str左侧的指定的字符,默认为空格

str26 = "    test is a very good girl"
print(str26.lstrip())
str26 = "*****test is a very good girl"
print(str26.lstrip("*"))

 

18.str.rstrip(s)

功能:截取str右侧的指定的字符,默认为空格

str27 = "test is a very good girl   "
print(str27.rstrip())
str27 = "*****test is a very good girl*****"
print(str27.rstrip("*"))

 

19.str.strip(s)
功能:截取str左右两侧的指定的字符,默认为空格

str28 = "****test is a very good girl****"
print(str28.strip("*"))

 

20.ord(s)、chr(97)

ord(s)功能:返回字符的ASCII码值

chr(97)功能:返回ASCII码值对应的字母

str29 = "z"
print(ord(str29))
print(chr(90))

 

21.字符串比较大小

#从第一个字符开始比较比较谁的ASCII码值大,谁就大
#如果第一个字符相等,则比较第二个以此类推

print("baaa" > "azzz")

 

22.split(str="",num)

#以str为分隔符截取字符串,指定num,则仅截取num个字符串

str30 ="testing*is**a***good*girl"
print(str30.split("*"))
print(str30.split("*",3))  #值截取3次,剩余部分是一个整体

 

23.splitlines([keepends]) 按照(\r \n \r\n)分隔,按行切割

#keeppends == True 会保留换行符,默认是False

str31 =''' testing is a good girl!
testing is a nice girl!
testing is a handsome girl!'''

print(str31.splitlines())
print(str31.splitlines(True))

 

24."".join(seq),以指定的字符串分隔符,将seq中的所有元素组合成一个字符串

list32 = ["testing","is","a","good","girl!"]
str33 = " ".join(list32)
str34 = "*".join(list32)
print(str33)
print(str34)

 

25.max(str),求字符串最大的元素

str35 = "testing is a nice girl!"
print(max(str35))

 

26.min(str),求字符串最小的元素,按Ascii来比较的,最小的是个空格所以看着像没打印一样

str36 = "testing is a nice girl!"
print(min(str36))

 

27.replace(old,new,num)将字符串num个的old替换成new,num不写默认为全部

str37 = "testing is a good good good girl!"
str38 = str37.replace("good","nice")  #全部替换
print(str37)
print(str38)
str39 = str37.replace("good","nice", 1)  #只替换一次
print(str39)

 

28.startswith(str[,start=0][end=len(str)]),在给定的范围内判断是否是以给定的字符串开头,默认整个字符串

str43 = "testing is a good girl!"
print(str43.startswith("testing"))
print(str43.startswith("tester"))
print(str43.startswith("testing",5,16))

 

29.endswith(str[,start=0][end=len(str)]),在给定的范围内判断是否是以给定的字符串结尾,默认整个字符串

str44 = "testing is a good girl!"
print(str44.endswith("girl"))
print(str44.endswith("tester"))
print(str44.endswith("girl",5,16))

 

30.编码

#encode(encoding="utf-8",errors="strict")
#encode(encoding="utf-8",errors="ignore"),ignore代表处理不处理

str45 = "testing is a good 测试!"
data46 = str45.encode()
print(data46)
print(type(data46))

 

31.解码

#decode(encoding="utf-8",errors="strict")
#decode(encoding="utf-8",errors="ignore"),ignore代表处理不处理

str47 = data46.decode("utf-8")  #这里要与编码时的encoding一致

print(str47)


str48 = data46.decode("gbk",errors="ignore")  #这里要与编码时的encoding一致,不一致会报错但是我的errors="ignore",即不处理错误,这样就会解码出乱码
print(str48)

 

32.isalpha():全是字母

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

str48 = "testing is a good girl"
print(str48.isalpha()) #返回False,因为有空格
str48 = "testingisagoodgirl"
print(str48.isalpha())

 

33.isalnum():全是数字和字母

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

str49 = "123ab "
print(str49.isalnum()) #返回False,因为有空格
str49 = "testing12agood32f3sl"
print(str49.isalnum())

 

34.isdigit():全是数字

#如果字符串只包含数字返回Ture,否则返回False

print("123".isdigit())  #返回True
print("123a".isdigit())  #返回False,因为有字母

 

35.isupper():如果是字母必须是大写

#如果字符串中至少有一个英文字符,且所有英文字符都是大写的,数字和其他字符没关系返回True,否则返回False

str50 = "Ad"
print(str50.isupper()) #返回False,因为小写字母
str50 = "22ADF"
print(str50.isupper())  #返回True

 

36.islower():如果是字母必须是小写

#如果字符串中至少有一个英文字符,且所有英文字符都是小写的,数字和其他字符没关系返回True,否则返回False

str51 = "Ad"
print(str51.islower()) #返回False,因为大写字母
str51 = "123#"
print(str51.islower()) #返回False,因为没有一个小写字母
str51 = "22adf#@"
print(str51.islower())  #返回True

 

37.istitle():标题化(每个单词的首字母大写)

#如果字符串是标题化的,返回True,否则返回False

print("Test Is".istitle())  #返回True
print("Test is".istitle())  #返回False,因为有一个单词的首字母没有大写
print("testing is".istitle())  #返回False,因为单词的首字母没有大写

 

38.isspace():只包含空白符(空格、\t、\n、\r、\r\n)

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

print(" ".isspace())  #返回True
print("  ".isspace())   #返回True
print("\t".isspace())  #返回True,因为\t出来是4个空格
print("\n".isspace())   #返回True
print("\r".isspace())    #返回True
print("\r\n".isspace())  #返回True

posted @ 2019-09-09 17:36  秒秒开心  阅读(473)  评论(0编辑  收藏  举报