5.16 列表生成式
1
2
3
4
5
6
7
8
|
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 列表生成式与生成器表达式的应用
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
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 导入方式一
1
2
|
import spam spam.read1() |
首次导入模块发生三件事 1、创建一个模块的名称空间 2、执行模块对应文件,将产生的名字存放于1中的名称空间 3、在当前执行文件中拿到一个模块名,该模块名指向1的名称空间
1
2
3
4
5
6
7
8
9
|
import spam 强调:之后的导入会直接引用第一次导入的结果,不会重复执行文件 import spam print (spam) 模块中功能的执行始终以模块自己的名称空间为准 read1 = 111111 #money=1000 spam.read1() #def read1(): # print('spam模块.read1:',money) #结果:spam模块.read1: 1000 |
为模块起别名:
1
2
3
4
5
6
7
8
|
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 导入方式二
1
2
3
4
|
from spam import money,read1,read2,change read1() from spam import * #从模块中导入所有方法 read1() #spam中:__all__=['money','read1'] 表示*能导入的方法,不写则表示能导入所有 |
首次导入模块发生三件事 1、创建一个模块的名称空间 2、执行模块对应文件,将产生的名字存放于1中的名称空间 提示:from...... import....... 与import前两件事一模一样 3、在当前名称空间中直接拿到模块中的名字,可以直接使用,不用加任何前缀同import,执行模块中的功能,始终以模块的名称空间为准
1
2
3
4
5
6
7
|
from spam import read1 money = 1111111111 read1() #结果:spam模块.read1: 1000 from ... import ......名字,拿到的名字可以不加前缀直接使用,使用起来更加方便, 但问题是容易与当前执行文件中相同的名字冲突 from spam import money money = 1111111111111111 print (money) #1111111111111111,而不是1000 |
为模块起别名:
1
2
|
from spam import money as m print (m) |
在一行导入多个
from spam import money,read1,read2
6.2 文件的两种执行方式:
1
2
3
4
5
6
7
8
9
10
11
|
#print(__name__) __name__的值: 1 、在文件被直接执行的情况下,等于 '__main__' 2 、在文件被导入的情况下,等于模块名 if __name__ = = '__main__' : print ( '文件被当中脚本执行啦。、。' ) read1() else : print ( '文件被导入啦' ) read2() |
6.3 模块的搜索路径
模块的查找顺序是:
内存中已经加载的模块 -----》内置模块-------》sys.path路径中包含的模块
1
2
3
4
5
|
import sys sys.path.append(r 'd:codesh_fullstack_s1day14dir1' ) import m1 m1.f1() |
强调 : sys.path的第一个路径是当前执行文件所在的文件夹
总结
以上所述是小编给大家介绍的python 中的列表生成式、生成器表达式、模块导入,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
原文链接:https://www.cnblogs.com/mylu/archive/2019/06/18/11048080.html