01-字符串
1.什么是字符串
使用单引号或者双引号括起来的字符集就是字符串(字符串是不可变的
)
字符串是不可变的,所以你不能仅仅改变或删除一个字符串里的某个字符,你能做的是删除整个字符串,或者是把剔除了不需要的部分后的字符串组合起来形成一个新串
2什么是转义字符
在Python中使用反斜杠符号( \ )来表示转义
转义占一个字符
转义字符 | 描述 |
---|---|
(在行尾时) | 续行符 |
\ | 反斜杠符号 |
' | 单引号 |
" | 双引号 |
\a | 响铃 |
\b | 退格(Backspace) |
\e | 转义 |
\000 | 空 |
\n | 换行 |
\v | 纵向制表符 |
\t | 横向制表符 |
\r | 回车 |
\f | 换页 |
\oyy | 八进制数,yy代表的字符,例如:\o12代表换行 |
\xyy | 十六进制数,yy代表的字符,例如:\x0a代表换行 |
\other | 其它的字符以普通格式输出 |
2.阻止转义
使用重复的两个反斜杠或者raw字符串
显示三个反斜杠
1.string=r'\\\n2'
print(string)
\\\n2
2.string='\\\\\\n2'
print(string)
\\\n2
3.编码
Python中字符串的字符编码是Unicode
ASCII编码是(8位)1个字节,而Unicode编码通常是(16位)2个字节
编码的目的是让字符可以存储在计算机中
Unicode包括了ASCII,表示世界上所有的语言和符号
编码转换 chr() 和 ord()
ord:把字符转换成Unicode
chr:把Unicode转换成字符
字符串比较大小的时候,从字符开始依次往后比较每个字符的大小,直到遇到字符不一样为止
比较字符大小的时候,实质比的是他们的编码的大小
print('abc'>'b')
False
print('a'>'ab')
False
3、使用三重引号编写多行字符串块
使用三引号可以允许一个字符串跨多行书写,我们有时候称其为块字符串。这个形式以三重引号开始(单引号和双引号都可以),并紧跟任意行数的文本,并且以和开始时同样的三重引号结尾。
Python把所有在三重引号之内的文本收集到一个字符串中,并在代码换行处嵌入了换行符。这种方式在程序中需要输入多行文本的任何时候都是很有用的。
三重引号字符串常用于文档字符串,当它出现在文件的特定地点时,会被当作注释一样的字符串常量。我们也经常在开发的过程中使用三重引号来废除一些代码。
02-获取字符串的字符
1.获取字符串的长度
len是获取序列长度的内置函数
length = len('abc\n123')
print(length)
7
2.通过下标获取字符串的某一个字符
字符串中每个字符都对应一个索引,可以通过索引获取固定字符
索引是从0开始的
使用索引运算符 [ ] 和切片运算符 [ : ] 可以得到子字符串。
string1 ='abc'
print(string1[0])
a
3.获取字符串中的部分字符(切片)
获取str4中的python
str4 ='hello python'
print(str4[6:12])
python
print(str4[-6:12])
python
4.获取整个字符串的内容
str4 ='hello python'
print(str4[:])
hello python
5.步长
str4 ='hello python'
print(str4[::4])
hot
6.字符串倒序
print(str4[::-1])
nohtyP loleh
print(str4[:-3:-1])
no
03-字符串运算符.
1.字符串的拼接: +
要么都是数字,要么都是字符串
str5 = 'hello'+' '+'python '
print(str5)
hello python
2.字符串重复 :*
str6=str5*5
print(str6)
hello python hello python hello python hello python hello python
3. in , not in
字符串1 in 字符串 2:判断在就是True 不在就是False
result = 'a' in 'abc'
print(result)
True
格式化字符串
符 号 | 描述 |
---|---|
%c | 格式化字符及其ASCII码 |
%s | 格式化字符串 |
%d | 格式化整数 |
%u | 格式化无符号整型 |
%o | 格式化无符号八进制数 |
%x | 格式化无符号十六进制数 |
%X | 格式化无符号十六进制数(大写) |
%f | 格式化浮点数字,可指定小数点后的精度 |
%e | 用科学计数法格式化浮点数 |
%E | 作用同%e,用科学计数法格式化浮点数 |
%g | %f和%e的简写 |
%G | %f 和 %E 的简写 |
%p | 用十六进制数格式化变量的地址 |
s8 = '%s 最喜欢的十进制数是:%d,\
八进制数字是:0o%o,最喜欢的十六进制数: 0x%x,
最喜欢的字母是:%c '%('小明',10,10,10,65)
print(s8)
小明 最喜欢的十进制数是:10,八进制数字是:0o12,最喜欢的十六进制数: 0xa ,最喜欢的字母是:A
04-字符串相关方法
序号 | 方法 | 描述 |
---|---|---|
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。 |
05-if,else,elif语句
根据Python的缩进规则,如果if语句判断是True,
就把缩进语句执行,否则,什么也不做。
if语句执行有个特点,它是从上往下判断,如果在某个判断上是True,
把该判断对应的语句执行后,就忽略掉剩下的elif和else
if <条件判断1>:
<执行1>
elif <条件判断2>:
<执行2>
elif <条件判断3>:
<执行3>
else:
<执行4>
只要x是非零数值、非空字符串、非空list等,就判断为True,否则为False。
练习
小明身高1.75,体重80.5kg。请根据BMI公式(体重除以身高的平方)帮小明计算他的BMI指数,并根据BMI指数:
低于18.5:过轻
18.5-25:正常
25-28:过重
28-32:肥胖
高于32:严重肥胖
用if-elif判断并打印结果:
h = input('请输入你的身高,按回车键确认(单位cm):')
height = float(h)/100
w = input('请输入你的体重,按回车键确认(单位kg):')
weight = float(w)
bmi = weight/height/height
if bmi <18.5:
print('你的bmi=',bmi,'体重过轻')
elif bmi <=25:
print('你的bmi=',bmi,'体重正常')
elif bmi <=28:
print('你的bmi=',bmi,'体重过重')
elif bmi <=32:
print('你的bmi=',bmi,'体重肥胖')
else:
print('你的bmi=',bmi,'严重肥胖')