一:学习内容

  • 字符串概念
  • 字符串运算
  • 字符串函数: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

python3笔记九:python数据类型-String字符串的更多相关文章

  1. python3.4学习笔记(九) Python GUI桌面应用开发工具选择

    python3.4学习笔记(九) Python GUI桌面应用开发工具选择 Python GUI开发工具选择 - WEB开发者http://www.admin10000.com/document/96 ...

  2. Python笔记_第一篇_面向过程_第一部分_5.Python数据类型之字符串类型(string)

    关于Python的字符串处理也如其他语言一样属于重点中的重点,主要是牵扯到的函数和内容较为多和乱一些.关于什么是字符串,Python中的定义是:以单引号或者双引号括起来的任意文本. 1.   字符串的 ...

  3. Python数据类型之字符串

    一:概述 Python中的字符串的一些概念 可以看作是字符的集合,在数据类型里没有单个字符的数据类型,可以用单个字符表示的一个字符串数据类型 字符串是一种不可变的序列类型,单个字符从左到右按照顺序排列 ...

  4. Python数据类型-02.字符串

    本文主要记录字符串的相关知识,包括字符串的定义特点,常用方法和 请知悉: 计算机中,一切皆为对象世界万物,皆为对象,一切对象皆可分类 1.什么是字符串? 类似"hello world&quo ...

  5. Python数据类型(字符串)

    文章内容参考了教程:http://www.runoob.com/python/python-basic-syntax.html#commentform Python 字符串 字符串是 Python 中 ...

  6. 3、python数据类型之字符串(str)

    字符串是任何计算机语言中最常见的数据类型,python中也不例外,因此熟练掌握字符串是学习python的必备技能.python中字符串三种定义方式 str = 'wang' str = "w ...

  7. python基础【2】——python数据类型之字符串

    python数据类型-字符串 一. 字符串的表示方法(str) 作用: 记录文本信息 表示方法:' ' 单引号 " "双引号 ''' '''三单引号 ""&qu ...

  8. Python 数据类型:字符串

    一.字符串介绍 字符串是由单引号/双引号/三引号引起来的,由字母 .数字或符号等构成的一串字符 In [1]: name = "Tom" # 定义字符串 In [2]: type( ...

  9. Python数据类型之字符串类型

    字符串的表示 字符串是Python中最常用的数据类型之一,必须使用成对的引号包围来表示字符串,引号可以是单引号 ' .双引号 " .三引号''' """,格式如 ...

随机推荐

  1. ArrayList扩容分析

    一段java代码 String e = "q3234v"; List<String> list = new ArrayList<String>(); for ...

  2. python+minicap(二)

    一.push文件至手机中 minicap 的使用有很强的针对性,针对不同架构的CPU和SDK制作了不同的 "minicap" 和 "minicap.so" 文件 ...

  3. SQL----Scalar 函数

    UCASE() 函数 UCASE 函数把字段的值转换为大写. SQL UCASE() 语法 SELECT UCASE(column_name) FROM table_name SQL UCASE() ...

  4. MySQL数据库基础-JAVA

    数据库 MySQL初步 MySQL基础认知 (Oracle真的是走哪祸害到哪23333) Java多用MySQL和Oracle SQLServer也收费,但是还行,比Oracle便宜,一个差不多3w多 ...

  5. 第十篇.1、python并发编程之多进程理论部分

    一 什么是进程 进程:正在进行的一个过程或者说一个任务.而负责执行任务则是cpu. 举例(单核+多道,实现多个进程的并发执行): egon在一个时间段内有很多任务要做:python备课的任务,写书的任 ...

  6. Linux 文件恢复(XFS & EXT4)

    在Linux中,删除rm命令使用需谨慎,有时候可能由于误操作,导致重要文件删除了,这时不要太紧张,操作得当的话,还是可以恢复的. EXT 类型文件恢复 删除一个文件,实际上并不清除inode节点和bl ...

  7. Linux三剑客:grep、awk、sed

    ---------------------------------------------------------------------------------------------------- ...

  8. springmvc自定义异常处理类和<mvc:annotation-driven/>自带异常处理优先级问题

    自定义异常类的优先级低于注解驱动的默认异常处理,所以可以给自定义异常处理类,实现一个排序的接口, org.springframework.core.Ordered 改接口的注释: /**  * {@c ...

  9. hdu 4747 线段树/DP

    先是线段树 可以知道mex(i,i),mex(i,i+1)到mex(i,n)是递增的. 首先很容易求得mex(1,1),mex(1,2)......mex(1,n) 因为上述n个数是递增的. 然后使用 ...

  10. 基于SDN4.2.4的neo4j实例

    首先添加maven依赖 (1)SND的声明 <dependency> <groupId>org.springframework.data</groupId> < ...