03 -Python笔记整理(字符串 if语句)

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,'严重肥胖')

你可能感兴趣的:(03 -Python笔记整理(字符串 if语句))