文章目录
供个人学习笔记回顾时使用.
1. 基础
-
print()输出 input()输入
r'
xxx'
xxx字符不需要转义
'''
xxx'''
xxx中间字符支持跨行 -
由于Python的字符串类型是str,在内存中以Unicode表示,一个字符对应若干个字节。如果要在网络上传输,或者保存到磁盘上,就需要把str变为以字节为单位的bytes。
Python对bytes类型的数据用带b前缀的单引号或双引号表示:x = b'ABC'
以Unicode表示的str通过encode()方法可以编码为指定的bytes,例如:
反过来,如果我们从网络或磁盘上读取了字节流,那么读到的数据就是bytes。要把bytes变为str,就需要用decode()方法:
len()函数计算的是str的字符数,如果换成bytes,len()函数就计算字节数:'中文'.encode('utf-8') b'ABC'.decode('ascii') # 如果bytes中只有一小部分无效的字节,可以传入errors='ignore'忽略错误的字节: b'\xe4\xb8\xad\xff'.decode('utf-8', errors='ignore') len('中文'.encode('utf-8')) # 6
-
模板字符串
%
print('Hi, %s, you have $%d.' % ('你好', 1000000)) # format函数也可以 'Hello, {0}, 成绩提升了 {1:.1f}%'.format('小明', 17.125) # 'Hello, 小明, 成绩提升了 17.1%'
%d, %s, %f, %x - 十六进制, 其余和C语言一样
%s会自动把数字也转换成字符串, 模板字符串里面如果想表达%
的话就写%%
-
循环不用多说了, 一个样,
for
…in
,while
, 记得最后加个:
names = ['Michael', 'Bob', 'Tracy'] for name in names: print(name) n = 1 while n <= 100: print(n) n = n + 1 print('END') # 判断一个对象是可迭代对象 from collections import Iterable isinstance('abc', Iterable) #true # 获取数组下标 for i, value in enumerate(['A', 'B', 'C']): print(i, value) # 循环 + range高级用法1 list(range(1, 11)) # [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] # 循环 + range高级用法2 [x * x for x in range(1, 11)] # [1, 4, 9, 16, 25, 36, 49, 64, 81, 100] # 循环 + range高级用法3 [x * x for x in range(1, 11) if x % 2 == 0] # [4, 16, 36, 64, 100] # 双层循环 + range [m + n for m in 'ABC' for n in 'XYZ'] # ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
-
条件判断, 这个稍有不同, 为
if
xxxelif
xxx
2. 类型
2.1. 有序集合list和tuple
list
classmates = ['Michael', 'Bob', 'Tracy']
# list是一个可变的有序表,所以,可以往list中追加元素到末尾:
classmates.append('Adam')
['Michael', 'Bob', 'Tracy', 'Adam']
# 把元素插入到指定的位置,比如索引号为1的位置:
classmates.insert(1, 'Jack')
['Michael', 'Jack', 'Bob', 'Tracy', 'Adam']
# 要删除list末尾的元素,用pop()方法:
classmates.pop()
['Michael', 'Jack', 'Bob', 'Tracy']
# 删除指定位置的元素,用pop(i)方法,其中i是索引位置:
classmates.pop(1)
['Michael', 'Bob', 'Tracy']
# 切片, 类似JS中的Slice, 如果第一个索引是0, 还可以简写classmates [:2]
classmates [0:2]
['Michael', 'Bob']
# -1就是最后一位
classmates [-1]
['Tracy']