部分边看边学的函数

字符串的前导字母含义

  • 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,回退一个字符。
如print("abcd\befg")

\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

看到最好的Flask_login 说明文章

https://www.cnblogs.com/alima/p/5818852.html

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值