python 之 列表生成式、生成器表达式、模块导入
程序员文章站
2022-07-09 21:30:14
5.16 列表生成式 5.17 列表生成式与生成器表达式的应用 第六章模块 什么是模块? 模块就是一系统功能的集合体,在python中,一个py文件就是一个模块,比如module.py,其中模块名module 6.1 import 导入模块 6.11 导入方式一 首次导入模块发生三件事 1、创建 ......
5.16 列表生成式
l=[]
for i in range(100):
l.append('egg%s' %i)
print(l)
l=['egg%s' %i for i in range(100)]
l=['egg%s' %i for i in range(1000) if i > 10]
print(l)
5.17 列表生成式与生成器表达式的应用
names=['egon','alex_sb','wupeiqi','yuanhao','lxx']
res=map(lambda x:x.upper(),names) # map函数 映射
names=list(res) #['egon', 'alex_sb', 'wupeiqi', 'yuanhao', 'lxx']
print(names)
names=['egon','alex_sb','wupeiqi','yuanhao','lxx']
names=[name.upper() for name in names] #列表生成式
print(names)
names=['egon','alex_sb','wupeiqi','yuanhao','lxx'] #列表生成式
names=[len(name) for name in names if not name.endswith('sb')]
print(names)
nums=[] #一般循环方法
with open('a.txt','r',encoding='utf-8') as f:
for line in f:
nums.append(len(line))
print(max(nums))
with open('a.txt','r',encoding='utf-8') as f:#列表生成式
nums=[len(line) for line in f]
print(max(nums)) #28
with open('a.txt','r',encoding='utf-8') as f:
nums=(len(line) for line in f) #生成器表达式
print(next(nums)) #15
print(next(nums)) #17
print(next(nums)) #13
print(max(nums)) #28
print(max(nums)) #空列表
max(len(line) for line in f) #去掉括号
第六章模块
什么是模块? 模块就是一系统功能的集合体,在python中,一个py文件就是一个模块,比如module.py,其中模块名module
6.1 import 导入模块
6.11 导入方式一
import spam
spam.read1()
首次导入模块发生三件事 1、创建一个模块的名称空间 2、执行模块对应文件,将产生的名字存放于1中的名称空间 3、在当前执行文件中拿到一个模块名,该模块名指向1的名称空间
import spam
强调:之后的导入会直接引用第一次导入的结果,不会重复执行文件
import spam
print(spam)
模块中功能的执行始终以模块自己的名称空间为准
read1=111111 #money=1000
spam.read1() #def read1():
# print('spam模块.read1:',money)
#结果:spam模块.read1: 1000
为模块起别名:
import spam as sm
sm.read1()
engine=input('>>: ').strip()
if engine == 'mysql':
import mysql as db
else engine == 'oracle':
import oracle as db
db.parse()
一行导入多个模块(不推荐使用)
import spam,mysql,oracle
6.12 导入方式二
from spam import money,read1,read2,change
read1()
from spam import * #从模块中导入所有方法
read1() #spam中:__all__=['money','read1'] 表示*能导入的方法,不写则表示能导入所有
首次导入模块发生三件事 1、创建一个模块的名称空间 2、执行模块对应文件,将产生的名字存放于1中的名称空间 提示:from...... import....... 与import前两件事一模一样 3、在当前名称空间中直接拿到模块中的名字,可以直接使用,不用加任何前缀
同import,执行模块中的功能,始终以模块的名称空间为准
from spam import read1
money=1111111111
read1() #结果:spam模块.read1: 1000
from ... import ......名字,拿到的名字可以不加前缀直接使用,使用起来更加方便, 但问题是容易与当前执行文件中相同的名字冲突
from spam import money
money=1111111111111111
print(money) #1111111111111111,而不是1000
为模块起别名:
from spam import money as m
print(m)
在一行导入多个
from spam import money,read1,read2
6.2 文件的两种执行方式:
#print(__name__)
__name__的值:
1、在文件被直接执行的情况下,等于'__main__'
2、在文件被导入的情况下,等于模块名
if __name__ == '__main__':
print('文件被当中脚本执行啦。、。')
read1()
else:
print('文件被导入啦')
read2()
6.3 模块的搜索路径
模块的查找顺序是:
内存中已经加载的模块 -----》内置模块-------》sys.path路径中包含的模块
import sys
sys.path.append(r'd:\code\sh_fullstack_s1\day14\dir1')
import m1
m1.f1()
强调 : sys.path的第一个路径是当前执行文件所在的文件夹
上一篇: Python 多进程