Python学习笔记 第四天
1 上次作业补充拓展
1.1 进制转换
format()
补充:‘b’二进制 ‘o’八进制 ‘d’十进制
‘x’十六进制
例:print(format(number,'b'))
int(string,number)将任意进制的字符转化为十进制
1.2 类型判断
type() 查询类型
isinstance() 判断一个对象是否是一个已知的类型,如若需要判断两个类型是否相同,推荐使用此函数
isinstance(object,classinfo) classinfo 可以直接是或间接类名,基本类型或者是它们构成的元组
isinstance()返回一个布尔类型
raise 显示引发的异常,程序出错时Python自动触发异常,也可以通过raise显示引发的异常。(相当于抛出异常)
执行raise后,后面的程序不再运行
2.今日学习内容
2.1 格式化输出
%s 字符占位符
%d 数字占位符
注意:"%d" 在Python中是不存在的,一般用%%表示字符串中%。但是如果语句中没有%d,%s等占位符,直接写一个%就好。
2.2 基本运算符
2.2.1 算术运算 :
+ - * / %(取余数) //(取整除) **(幂)
2.2.2 比较运算 :
== != <>(不等于) > < >= <=
2.2.3 赋值运算 :
= +=(自增运算) -=(自减运算) *= /=
//= %=
**=(幂等 a ** = b 等价于 a = a*a*b)
2.2.4 逻辑运算 :
or and not
逻辑运算的优先级顺序 :
() > not > and >or
2.3 编码
2.3.1 存储单位
bit 最小的存储单位
8 bit = 1 Byte 一字节
1024 B = 1 KB (KiloByte) 千字节
1024 KB = 1 MB (MegaByte) 兆字节
1024 MB = 1 GB (GigaByte) 吉字节
1024 GB = 1 TB (TeraByte) 太字节
1024 TB = 1 PB (PetaByte) 拍字节
1024 PB = 1 EB (ExaByte) 艾字节
1024 EB = 1 ZB (ZetaByte) 泽字节
1024 ZB = 1 YB (YottaByte) 尧字节
1024 YB = 1 BB (Brontobyte) 珀字节
1024 BB = 1 NB (NonaByte) 诺字节
1024 NB = 1 DB (DoggaByte) 刀字节
2.3.2 编码
ASCII :最多支持256个字符。具体内容请自行百度
GBK :仅限中国地区使用,每个字符占16位(2字节)
Unicode :万国码
UTF-8 :每个字符最少占8位
UTF-16: 每个字符占16位
2.4 切片
2.4.1 切片处理
使用下标来获取部分字符串内容
print(字符串名[开始位置:结束位置:截取步长]
注意:截取顾头不顾尾,设置步长则会进行跳跃式截取
2.4.2 字符串处理
str.capitalize() :字符串首字母大写
str.lower() :字符串全部小写
str.upper() :字符串全部大写
str.title() :字符串每个单词首字母进行大写
str.center() :字符串居中处理
str.strip() :去除字符串左右两端空格
str.lstrip() :去除字符串左边空格
str.rstrip() :去掉字符串右边空格
str.replace("要被更换的内容","更改的内容")
字符串的部分替换
str.split("切割标记") :对字符串按标记进行切割
注意:字符串的位置不同,导致截取的结果可能也不同(注意缩进)
s9 = """
左牵黄
右擎苍
锦帽貂裘
千骑卷平冈
为报倾城随太守
亲射虎
看孙郎
"""
print(s9.split(" "))
输出结果:
['', '左牵黄', '右擎苍', '锦帽貂裘', '千骑卷平冈', '为报倾城随太守', '亲射虎', '看孙郎', '']
情况二:
s9 = """左牵黄
右擎苍
锦帽貂裘
千骑卷平冈
为报倾城随太守
亲射虎
看孙郎"""
print(s9.split(" "))
输出结果:
[ '左牵黄', '右擎苍', '锦帽貂裘', '千骑卷平冈', '为报倾城随太守', '亲射虎', '看孙郎']
所以需要注意,字符串的位置不同,导致截取的结果可能也不同
str = "XXX%s,XXX%s"%(内容一,内容二)
str = "XXX{},XXX{}".format(内容一,内容二)
注意:如无特别注明,默认按照顺序打印对应内容,不同的出入方式,所打印的结果也可能会有所不同
例:
str = "我叫{},今年{}岁了".format("kaka",2)
str = "我叫{name},今年{age}岁了".format(name ="kaka",age = 2)
str = "我叫{1},今年{2}岁了".format("kaka",2)
str.startswith("要判断的文字") : 判断字符串的开头,返回布尔类型
str.endswith("要判断的文字"):判断字符串的结尾,返回布尔类型
str.count("要统计的文字"):统计字符串中某字符出现的次数
str.find("要查找的文字"):查找字符串中的某个字符位置,如果未查询到,返回 -1
str.find("要查找的文字",开始位置,结束位置):从指定位置查找字符(切片式查找),找到第一个出现的位置。如果未查询到,返回-1
str.index("要查找的字符"):查找特定字符的位置,如果未查询到,报告错误
str.isalnum() :判断字符串是否全是字母或数字组成
str.isalpha() :判断字符串是都全是字母组成 注意:判断时,空格也会被进行判断
str.isdigit() :判断字符串是否只由数字组成。
str.islower() :判断字符串是否由小写字母组成。
str.isnumeric() :判断字符串是否只由数字组成。注意:一、这种方法是只针对unicode对象。二、定义一个字符串为Unicode,只需要在字符串前添加 'u' 前缀即可
str.isspace() :判断字符串是否只由空格组成
str. istitle() :判断字符串中所有的单词拼写首字母是否为大写,且其他字母为小写。
str.isupper():判断字符串中所有的字母是否都为大写
str.join(要连接的元素序列) :将序列中的元素以指定的字符连接生成一个新的字符串
2.4.3列表处理
2.4.3.1 常见操作
len(对象名):当前字符串长度(内置函数,可直接调用)
print(list[索引下标])
print(list[索引下标][元素内字符下标])
print(list[索引开始下标:索引结束下标:截取步长])
注意:截取顾头不顾尾,设置步长则会进行跳跃式截取,“-”代表倒取,即从末端位置反向截取
2.4.3.2 列表的增删改查操作
2.4.3.2.1 增 append方法(末端添加)
例:
list = []
while True:
content = input("请输入您的信息,输入Q退出!!!")
if content.upper() == 'Q':
break
list.append(content)
print(list)
2.4.3.2.2 删
2.4.3.2.2.1 pop方法
注意:pop(指定位置下标),下标若未指明,则默认删除最后一个
2.4.3.2.2.2 del方法(切片式删除)
del[删除开始位置:删除结束位置]
2.4.3.2.3 改(切片式修改)
list[开始下标:结束下标:截取步长]= [对应修改的元素]
注意:截取顾头不顾尾,设置步长则会进行跳跃式截取,“-”代表倒取,即从末端位置反向截取
2.4.3.3 输出
循环输出
for item in 列表名:
print(item)
2.4.3.4 列表的嵌套
采用降维操作,一层一层的去找,切勿心急
例:
list = ["张三","李四","王五","赵六","田七",["CXK","101","Sky","801","183"]]
print(list[-1][0:2])
输出结果
['CXK', '101']
2.4.3.5 元组的嵌套
元组元素不可修改,但是如果其中嵌套的有列表等可变形式,那么这个可变形式中的元素可以进行修改。
换言之,元组的不可变性只针对子元素,如若子元素的内部是可变对象,那么,元组中的子元素的子元素是可变的。