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)) #
with open('a.txt','r',encoding='utf-8') as f:
nums=(len(line) for line in f) #生成器表达式
print(next(nums)) #
print(next(nums)) #
print(next(nums)) #
print(max(nums)) #
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的第一个路径是当前执行文件所在的文件夹

最新文章

  1. GreenDao的使用
  2. jmeter分布式操作-远程启动功能探索
  3. location对象说明
  4. VS工具--GhostDoc
  5. VisualStudio.gitignore git 忽略
  6. Android之垂直显示TextView
  7. Nginx日志常用分析命令汇总 (转)
  8. Effective Java 36 Consistently use the Override annotation
  9. .ecp认证文件(10.3版本)
  10. CoreOS 835.12.0 稳定版安装
  11. java双亲委派模型如何递归实现
  12. hadoop中汉字与英文字符混合的keyword做为combine的key的问题
  13. CodeBlocks
  14. 原生nodejs在线聊天系统
  15. DCOS实践分享(1):基于图形化模型设计的应用容器化实践
  16. 优秀的电商平台Jshop栗子
  17. 笨办法40模块, 类和对象class
  18. get通配符
  19. Linux GCC编译
  20. JavaScript 正则表达式的入门与使用

热门文章

  1. Ruby 文件 FILE
  2. git删除远程分支【转】
  3. <密码学入门>关于DES加密算法解密算法相关问题
  4. Hadoop- MapReduce在实际应用中常见的调优
  5. Hadoop HA- hadoop集群部署
  6. 存储过程之rowtype 使用
  7. EntityFramework Code First 构建外键关系,数据库不生成外键约束
  8. VMware vs openStack对比直观优势
  9. 0001_第一个测试小程序Login
  10. ubuntu下caffe配置