python常用内置方法
常用内建函数
# 如何在遍历一个列表的同时获取当前下标?
# 普通人的做法
list = [1, 2, 3, 4, 5, 6]
index = 0
for i in list:
print('下标%s' % index, i)
index += 1 # 大佬的做法
list = [1, 2, 3, 4, 5, 6]
for i, j in enumerate(list):
print('下标%s' % i, j)
# 如何使用函数修饰被迭代对象来优化循环
# 普通人的做法
list1 = [1, 2, 3, 4, 5, 6]
list2 = [2, 3, 4, 5, 6, 7]
list3 = [3, 4, 5, 6, 7, 8]
for i in list1:
for j in list2:
for k in list3:
if i + j + k == 10:
print(i, j, k)
# 大佬的做法
from itertools import product
for i, j, k in product(list1, list2, list3):
if i + j + k == 10:
print(i, j, k)
#无限迭代器的使用
#普通人的做法
na = 2
while True:
print(na)
na +=1 #大佬的做法
from itertools import count
for i in count(2):#参数:表示从几开始
print(i)
#无限重复之迭代器的使用
#普通人都做法
res = 'ABC'
while True:
for i in res:
print(i) #大佬的做法
from itertools import cycle
for i in cycle('ABC'):
print(i)
#如何找到列表中的元素进行无限重复,并可用控制重复的次数
#普通人都做法
list = [1,2,3,4,5,6]
for i in list:
if i==list[2]:
for j in range(10):
print('',list[2]) #大佬的做法
from itertools import repeat
list = [1,2,3,4,5,6]
res = repeat(list[2],10)#参数一:表示从几开始,参数二:表示重复次数
for i in res:
print('',i)
# 如何使用 islice 实现循环内隔行处理
需要把a.txt文件中的'---'去掉
1234
---
aadd
---
sadsad
---
asdasdad
# 普通人的做法
def test():
with open('a.txt', 'r') as fp:
for i, line in enumerate(fp):
# 跳过无意义的 '---' 分隔符
if i % 2 == 0:
yield line.strip()
for i in test():
print(i) # 大佬的做法
from itertools import islice
# islice(seq, start, end, step) 函数和数组切片操作*( list[start:stop:step] )有着几乎一模一样的参数。
# 如果需要在循环内部进行隔行处理的话,只要设置第三个递进步长参数 step 值为 2 即可(默认为 1 )*。
def parse_titles_v2():
with open('a.txt', 'r') as fp:
# 设置 step=2,跳过无意义的 '---' 分隔符
for line in islice(fp, 0, None, 2):
yield line.strip()
for i in parse_titles_v2():
print(i)
# 使用 takewhile 替代 break 语句
# 普通人的做法
list = [1, 2, 3, 4, 5, 6]
for i in list:
if i == 4:
break
else:
print(i) # 大佬的做法
from itertools import takewhile
list = [1, 2, 3, 4, 5, 6]
for i in takewhile(lambda x: x != 4, list):#参数一:限制条件函数,list表
print(i)
#如何使用列表链(将一组迭代对象串起来,形成一个更大的迭代器)
#普通人的做法
v1 = [11,22,33]
v2 = [44,55,66]
all = v1+v2
for c in all:
print(c) #大佬的做法
from itertools import chain
v1 = [11,22,33]
v2 = [44,55,66]
new_list = chain(v1,v2)
for c in new_list:
print(c)
#偏函数的使用
from functools import partial
def fuc1(a1,a2):#一个函数有两个参数
print('fuc1',a1,a2)
return a1-a2
def fuc2(a3,a4):
print('fuc2',a3,a4)
return a3+a4
new_fuc = partial(fuc1,fuc2(1,2))#functools.partial可以传函数名和fuc的第一个参数
res = new_fuc(3)
print(res)
#----------结果
#fuc2 1 2
#fuc1 3 3
#
# 这样理解执行函数先执行fuc2,打印fuc2 1 2
# fuc2的返回值和fuc1函数存放在new_fuc对象中
# new_fuc(3),把3传入fuc1函数的a1,把fuc2返回值放入a2,打印fuc2 3 3
# res打印0
累加
from itertools import accumulate
_list = [1,2,3,4,5,6]
print(list(accumulate(_list)))#[1, 3, 6, 10, 15, 21]
#实现累加的函数
importlib内置模块
文件目录

#a.py
class A(object):
def public(self):
print('aaa')
#b.py
class B(object):
def public(self):
print('bbb')
#c.py
class C(object):
def public(self):
print('ccc')
#co.py
from importlib import import_module
M = [
'util.a.A',
'util.b.B',
'util.c.C',
]
for m in M:
import_class,method_class = m.rsplit('.',maxsplit=1) #按最后右边的'.'分割,获取文件路径对象名称和成员对象名称,maxsplit=1表示最大分割一次
r = import_module(import_class) #自动导入文件
oo =getattr(r,method_class) #获取导入文件中的成员对象,此时oo就是每个class对象
res = oo() #实例化
res.public() #执行公共方法
#借鉴了jdango中使用字符串导入模块的功能,好处是减少耦合,功能模块可以自如开关
# 普通人的做法
class Api1:
def __init__(self, b: tuple):
self.a: tuple = (1, 2, 3, 4,)
self.b: b = self.a + b res1 = Api1((5, 6,))
print(res1.a) # (1, 2, 3, 4)
print(res1.b) # (1, 2, 3, 4, 5, 6) # 大佬的做法
class Api2:
def __init__(self, b: tuple):
self.a = (1, 2, 3, 4,)
self.b = self.a + b res2 = Api2((5, 6,))
print(res2.a) # (1, 2, 3, 4)
print(res2.b) # (1, 2, 3, 4, 5, 6)
python常用内置方法的更多相关文章
- 递归,装饰器,python常用内置方法
**递归** def calc(n): print(n) if int(n / 2) == 0: 条件判断 r ...
- python常用内置方法index\extend\count\reverse\sort
定义列表:(有2个值相同) a = ['XiaoBao','aiaoHao','biaoLiao','ciaoQing','eiaoLi','QiBao','biaoLiao'] 列表的索引: fir ...
- python字符串常用内置方法
python字符串常用内置方法 定义: 字符串是一个有序的字符的集合,用与存储和表示基本的文本信息. python中引号中间包含的就是字符串. # s1='hello world' # s2=&quo ...
- python迭代器-迭代器取值-for循环-生成器-yield-生成器表达式-常用内置方法-面向过程编程-05
迭代器 迭代器 迭代: # 更新换代(其实也是重复)的过程,每一次的迭代都必须基于上一次的结果(上一次与这一次之间必须是有关系的) 迭代器: # 迭代取值的工具 为什么用迭代器: # 迭代器提供了一种 ...
- 迭代器,for循环本质,生成器,常用内置方法,面向过程编程
一.迭代器 1.迭代:更新换代(重复)的过程,每次的迭代都必须基于上一次的结果 迭代器:迭代取值的工具 2.迭代器给你提供了一种不依赖于索引取值的方式 3.可以迭代取值的对象:字符串,列表,元组,字典 ...
- python常用内置函数和关键字
常用内置方法 在Python中有许许多多的内置方法,就是一些Python内置的函数,它们是我们日常中经常可以使用的到的一些基础的工具,可以方便我们的工作. 查看所有的内置类和内置方法 # 方法一 bu ...
- python 字典内置方法get应用
python字典内置方法get应用,如果我们需要获取字典值的话,我们有两种方法,一个是通过dict['key'],另外一个就是dict.get()方法. 今天给大家分享的就是字典的get()方法. 这 ...
- Python的内置方法,abs,all,any,basestring,bin,bool,bytearray,callable,chr,cmp,complex,divmod
Python的内置方法 abs(X):返回一个数的绝对值,X可以是一个整数,长整型,或者浮点数,如果X是一个复数,此方法返回此复数的绝对值(此复数与它的共轭复数的乘积的平方根) >>> ...
- Python 类的常用内置方法
类的内置方法(魔法方法): 凡是在类内部定义,以__开头__结尾的方法,都是类的内置方法,类的内置方法,会在满足某种条件下自动触发. 1.1__new__ __new__:在___init__触发前, ...
随机推荐
- 利用ldirectord实现lvs后端realserver健康状态检查
ldirectord用来实现LVS负载均衡资源在主.备节点间的故障转移.在首次启动时,ldirectord可以自动创建IPVS表.此外,它还可以监控各RealServer的运行状态,一旦发现某Real ...
- SORRY_FOR_MY_LIFE
人生最大的痛苦不在于真正的痛苦, 而是没有确切的人生方向, 我们总是想的很多, 但是最后才发现, 我们一直拿自己的弱点与别人的长处竞争, 因为,我们总是得不到自己想要的, 但是最多的是对于没有目标的人 ...
- canal启动报错ERROR c.a.o.canal.parse.inbound.mysql.dbsync.DirectLogFetcher - I/O error while reading from client socket
- 线性链条件随机场(CRF)的原理与实现
基本原理 损失函数 (线性链)CRF通常用于序列标注任务,对于输入序列\(x\)和标签序列\(y\),定义匹配分数: \[ s(x,y) = \sum_{i=0}^l T(y_i, y_{i+1}) ...
- 使用gomod后,导入模块与编译要注意的事项
问题:在使用go mod后,执行编译会报错: Cannot load xxx: cannot find module providing package xxx 目录结构如下: J:. │ └─src ...
- 自然语言处理(简称NLP)
自然语言处理(简称NLP),是研究计算机处理人类语言的一门技术,包括: 1.句法语义分析:对于给定的句子,进行分词.词性标记.命名实体识别和链接.句法分析.语义角色识别和多义词消歧. 2.信息抽取:从 ...
- Mysql 定时备份(mysqldump)
#!/bin/bash today=`date +%Y-%m-%d` deleday=`date -d '7 day ago' +%Y-%m-%d` path=/home/data/mysqlback ...
- Python基础 — 数据类型转换
Python 数据类型转换 有时候,我们需要对数据内置的内心进行转换,数据类型的转换,你只需要将数据类型作为函数名即可. 以下几个内置的函数可以执行数据类型之间的转换,这些函数返回一个新的对象,表示转 ...
- 立体像对空间前方交会-共线方程求解法(python实现)
一.原理 二.步骤 a.用各自像片的角元素计算出左右像片的旋转矩阵R1和R2. b.有同名像点列出共线方程. c.将方程写为未知数的线性方程形式,计算线性系数. d.写出误差方程,系数矩阵与常数项. ...
- 2019牛客多校九 I. KM and M (类欧几里得)
大意: 给定$N,M$, 求$\sum\limits_{K=1}^N \text{(KM)&M}$ 考虑第$i$位的贡献, 显然为$\lfloor\frac{KM}{2^i}\rfloor$为 ...