字符串的前导字母含义
- f : 字符串前面加f表示使用格式化字符串(f-string)的方式定义字符串,如f"我叫{name}"
- r: r字符串前缀是一种特殊的字符串前缀,用于表示原始字符串。当一个字符串以r前缀开始时,它将被视为原始字符串,其中的转义字符将被忽略。如:r"D:\LiRen\SmartPython\050\abc.txt",其中的\050就不会转义。
- u: 字符串值前面的’u’符号表示该字符串是Unicode字符串。通过加上’u’符号,Python可以识别并正确处理字符串中的Unicode字符。 一般如果源码不是用utf-8保存会使得源码显示有问题才用,但现在一般都是用“utf-8”保存源码的,所以这个基本用不太上了。
- b: 当字符串前添加“b”时,表示这个字符串是一个字节字符串(bytes),而不是Unicode字符串(str)。字节字符串中的每个元素都是一个0~255范围内的整数,并且支持bytes对象的方法,如decode和encode方法。主要用于处理二进制文件,如图片、音频、视频等,方便网络传输。encode()->把中文字符处理成字节流,decode()->把字节流还原成中文。
- fr:可以并用,如下面由于有了r 前导符,直接显示了\t:
转义字符说明;
\r: return,就是print中加了这个,就是自动抹掉前的字符,
比如 print(“1234\r”) 就好比打印完1234后又重新回到这一行(不是另起一行)开头再打印其他的。
\t: tab
\n: newline
\b: back,回退一个字符。
\a:提示音,在pycharm直接运行无效,要在cmd中运行py文件有效
\u:\u + 4个字符,用unicode表示中文字符,如“ \u5367\u69fd ’ 就是中文“卧槽”
\u+2个字符,用unicode表示ascII码255以内的字符,类似这样 (‘\xe4\xb8\xad\xe6\x96\x87’)
ASCII码
chr:asc码转字符
ord:字符转asi码
高阶函数(map,reduce,filter,sorted)
- map: map(func, *iterables) --> map object 生成map类型,后续要再转换成需要的类型,比如dict(map(…)),list(map(…))
参数1:是个函数,可以是用lambda匿名函数,也可以是def定义的函数
参数2:必须是迭代对象
功能:将参数2迭代对象中的每一个项目用参数1函数去运算(参数1 中最短的迭代耗尽就停止),生成一个新的迭代对象。
def f(x):
return x*x
print (list(map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])))
# 输出结果: [1, 4, 9, 10, 25, 36, 49, 64, 81]
l2 = map(lambda x,y:x**y,[1,2,3],[1,2,3])
print('l2=',l2)
print('list(l2)=',list(l2)
# 输出结果:l2 = <map object at 0x000001AA3AFEAE20>
# 输出结果:list(l2) = [1,4,27]
lambda: 匿名函数
>g = lambda x:x+1
>g(2)
>>>3
>lambda x:x+1(1)
>>>2
>a = lambda x,y,z:(x+8)*y-z
print(a(5,6,8))
关于Python的两个魔法方法:repr__和__str
repr 目的是为了表示清楚,是为开发者准备的。应该尽可能的表示出一个对象来源的类以及继承关系,方便程序员们了解这个对象。
str 目的是可读性好,是为使用者准备的。简单的表示对象,而不要让不懂编程的以为输出的是 bug。
具体可参考:
https://blog.csdn.net/sinat_41104353/article/details/79254149#%E4%BE%8B%E5%AD%90
uuid: 就是生成随机数
- uuid.uuid1(),基于MAC地址,时间戳,随机数来生成唯一的uuid,可以保证全球范围内的唯一性。
- uuid.uuid2(),算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。不过需要注意的是python中没有基于DCE的算法,所以python的uuid模块中没有uuid2这个方法。
- uuid.uuid3(namespace,name) 通过计算一个命名空间和名字的md5散列值来给出一个uuid,所以可以保证命名空间中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。【感谢评论区大佬指出】namespace并不是一个自己手动指定的字符串或其他量,而是在uuid模块中本身给出的一些值。比如uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_OID这些值。这些值本身也是UUID对象,根据一定的规则计算得出。
- uuid.uuid4() 通过伪随机数得到uuid,是有一定概率重复的
- uuid.uuid5(namespace,name) 和uuid3基本相同,只不过采用的散列算法是sha1
一般而言,在对uuid的需求不是很复杂的时候,uuid1方法就已经够用了
python for 循环 一个 list 获取index
使用 enumerate 函数 可以返回下标。 例如
for inx, val in enumerate(['uyy', 'dfdf']):
print(inx)
print(val)
结果是
0
uyy
1
dfdf
python中列表list、字典dict找最大值、最小值
https://blog.csdn.net/weixin_41770169/article/details/80816886
Flask 静态文件缓存问题
https://cuiqingcai.com/5984.html