一,复习

'''
装饰器
@wraper # fn = wraper(fn)
def fn(): pass def wrap(arg):
def outer(func):
# 可以用arg
def inner(*args, **kwargs):
# 可以用arg
res = func(*args, **kwargs)
return res
return inner
return outer @wrap('实参')
def fn(): pass # 更改inner的文档注释指向
  from functools import wraper 三元表达式:a if a > b else b 列表、字典推导式: [v for v in iterable] {k: v for k, v in iterable}
  ['奇数' if v % 2 == 1 '偶数' for v in range(1, 11)] 迭代器:
  # 有__iter__() => 可迭代对象
  # 有__next__() => 迭代器对象
  # for迭代器
  # enumerate => 为可迭代对象生成索引 生成器:自定义的迭代器
# range
def fn():
msg = yield 1
yield 2
obj = fn()
obj.__next__()
obj.send(msg) 递归:函数的自调用
# 回溯
# 递堆
# 条件与出口 匿名函数:lambda 内置函数:max | min | sorted | map | reduce
max(dic, key=lambda k: dic[k]) '''

二,今日内容

'''
1.模块
-- 模块的概念
-- 模块的使用
-- 解决循环导入 2.包
-- 包的概念
-- 包的管理 *** 3.常用模块
-- sys | os | time | datetime | json | random
-- re | logging | hashlib
'''

三,模块

# 模块的概念:一系列功能的集合体,可以给其他文件提供功能(数据)

'''
常见的四种模块:
1.使用python编写的.py文件
2.把一系列模块组织到一起的文件夹(注:文件夹下有一个__init__.py文件,该文件夹称之为包)
3.使用C编写并链接到python解释器的内置模块
4.已被编译为共享库或DLL的C或C++扩展
''' # 模块的创建与使用
# 1.将具有共性的功能放在一个py文件中,这样的文件就可以称之为模块
# 2.将封装好的模块对外提供功能
# 3.在要使用模块功能的地方进行导入 => 使用功能
# 语法:import 模块名 # m1.py
def t1():pass
def t2():pass
def t3():pass # 导入模块完成了哪些事
import m1 # m1名字就是模块m1的文件对象,存放的是m1文件的地址
# import导入模块完成的事情:
# 1.将被导入的模块编译成模块名对应的pyc文件
# 2.从上至下执行被调用模块的所有代码,形成模块的名称空间,将模块中产生的所有名字存放在模块的名称空间中
# -- t1,t2,t3存放在m1模块的名称空间中
# 3.在要使用模块的文件(当前文件)的名称空间中产生一个与模块名同名的名字指向模块的名称空间
# print(m1) # 重点:在一个文件中直接使用名字,一定找当前文件中的名字 # 执行文件与模块的名称空间如果建立起联系的:通过导入的模块名,所以执行文件访问模块文件中的名字用
# -- 模块名.模块中的名字

四,模块别名

import 模块名 as 别名

# 1.模块名与当前文件中的名字发生冲突,用起别名解决冲突
# 2.优化模块名
# 注意:一旦起别名,别名就指向了模块地址,模块名就没有要指向模块地址的必要,那么就失效

五,模块的多次导入

# 第一次导入模块,已经完成导入模块的三步,
# 编译=>运行(产生名称空间存放名字)=>执行文件产生名字指向模块的名称空间 # 再次导入:前两步是重复操作,所以只会在当前文件再产生一个名字指向模块的名称空间 # 理由:前两步操作已经将资源放置内存中,从内存中查找速度极高,优先找内存 import m1
import m1
# 相当于:a = 10 | a = 10 import m1
import m1 as m
# 相当于:a = 10 | b = a

六,模块在链式导入时的执行流程

# 执行文件.py
print('加载')
import m1 # 进入m1, m1全部走完回到这里
print('结束') # m1.py
print('m1 开始')
x = 10
import m2 # 进入m2, m2全部走完回到这里
print('m1 结束') # m2.py
print('m2 开始')
y = 20
print('m2 结束') '''
加载
m1 开始
m2 开始
m2 结束
m1 结束
结束
'''
# 注:在执行文件中访问20
print(m1.m2.y)

七,from...import 语法

# 可以进入模块导具体的名字

from m1 import a
# from导入的三步:
# 前两步同import导入
# 第三步:在执行文件起一个与模块中名字相同的变量指向那个名字的地址:a = m1.a # 起别名
from m1 import b as bbb # bbb = m1.b
print(bbb) # 了了解:不推荐
from m1 import *
# 1)默认将m1中的所有不是以_开头的名字进行导入,在当前执行文件中可以直接使用模块中的名字
# 2)本质导入的是m1模块中__all__管理的名字 ['a', 'b'],被管理的名字可以任意自定义(可以包含_开头)
# 3) 这种方式的导入,名字不能被起别名,一旦发生名字冲突,无法解决

八,模块的两种执行方式

自执行:
# 在模块中的__name__ = '__main__'

作为模块被导入执行
# 在模块中的__name__ = '模块名'

共存

# 模块文件 # 先写所有的模块资源(数据 与 函数)
pass # 模块最下方
if __name__ == '__main__':
# 自执行的逻辑代码
pass

九,模块的加载顺序

# 内存 > 内置 > sys.path的路径顺序遍历 自定义模块(自己写的,系统写的第三方,别人写的第三方)

# 环境变量: 只是辅助于当前运行的项目,不会影响系统,也不会影响其他项目,所有可以随意操作
import sys
sys.path # 存放各种模块文件夹路径的列表,可以任意操作来绝对导入自定义模块的顺序

十,import与from...import:导入的方式采用的是绝对路径

# 绝对路径的依赖:环境变量 sys.path

十一,环境变量的项目运行

# 在实际开发中,多文件夹之间的模块导入,结构层次杂乱无章,如何规律且准确的进行导包

# 如:项目下part8\a\test.py 导入part8\a\m1.py | part8\a\b\m2.py| part7\c\m3.py
  from part8.a import m1
  from part8.a.b import m2
  from part7.c import m3
# 只需要保证项目目录在环境变量中即可

十二,项目目录分析

bin: 可执行文件
conf:项目的配置文件
core:项目核心文件,主要的业务逻辑代码
db:数据库相关文件
interface:接口文件
lib:项目的依赖库
log:日志文件
static:静态资源
tmp:临时文件 # 如何将项目所在目录添加至环境变量
# 比如执行文件 项目目录\bin\run.py => 项目目录添加到环境变量的语句
  import sys
  import os
  sys.path.append(os.path.dirname(os.path.dirname(__file__)))

十三,循环导入

# *****

# 问题:彼此相互导入,并使用彼此的名字,如果导入在名字产生之前,就会导致找不到名字,从而出现循环导入错误

# 解决:将名字的产生定义在导入模块之前(延迟导入)

# m1.py
xxx = 666
from m2 import yyy # m2.py
yyy = 888
from m1 import xxx

十四,包

# 包:一系列模块的集合体,可以给其他文件提供功能(数据)
# 很多模块的功能相似,将他们统一管理,放在一个文件夹中,该文件夹就称之为 包 # 注:包与普通文件夹不一样,包中必须有__init__文件,py3中可以省略,系统会默认添加,py2中必须手动添加否则报错

  

十五,导包

import 包名
import 包名 as 别名 # 导包的三步
# 1) 创建包下__init__文件对应的pyc文件
# 2) 执行__init__文件产生包的名称空间,将__init__文件中的名字放置到包的名称空间中
# 3) 在执行的导包文件中产生一个包名指向包的名称空间 = __init__文件的名称空间 # __init__文件中出现的名字都可以直接用 包名.名字 来使用 # 包m的__init__.py文件
num = 666 # 导包文件
imprt m
print(m.num)

十五,包的管理

# 1.导包的以.开头的语法,属于包内语法,因为存在.语法开头的导包文件,都不能自执行
# 2.导包的以.开头的语法,只能和 from 结合使用
# 3.在包中的任意模块中都可以使用.语法访问包中其他模块中的名字
# 4.包中.代表当前目录,再添加一个.也就是..代表上一级目录

周末学习笔记——day03(模块,包)的更多相关文章

  1. [转帖]Linux学习笔记之rpm包管理功能全解

    Linux学习笔记之rpm包管理功能全解 https://www.cnblogs.com/JetpropelledSnake/p/11177277.html rpm 的管理命令 之前学习过 yum 的 ...

  2. OpenCV图像处理学习笔记-Day03

    OpenCV图像处理学习笔记-Day03 目录 OpenCV图像处理学习笔记-Day03 第31课:Canny边缘检测原理 第32课:Canny函数及使用 第33课:图像金字塔-理论基础 第34课:p ...

  3. Python学习笔记之模块与包

    一.模块 1.模块的概念 模块这一概念很大程度上是为了解决代码的可重用性而出现的,其实这一概念并没有多复杂,简单来说不过是一个后缀为 .py 的 Python 文件而已 例如,我在某个工作中经常需要打 ...

  4. Python学习笔记—itertools模块

    这篇是看wklken的<Python进阶-Itertools模块小结> 学习itertools模块的学习笔记 在看itertools中各函数的源代码时,刚开始还比较轻松,但后面看起来就比较 ...

  5. python学习笔记十——模块与函数

    第五章 模块与函数 5.1 python程序的结构 函数+类->模块              模块+模块->包                 函数+类+模块+包=Python pyth ...

  6. Python3学习笔记25-logging模块

    logging模块,Python自带用来记录日志的模块. 因为工作需要用到关于日志的,最近一直都在看关于日志模块的东西,百度了很多文章,可惜都是看的让人一头雾水,最后运气不错,找到一篇很详细的文章.传 ...

  7. Python学习笔记 - day9 - 模块与包

    模块与包 一个模块就是一个包含了Python定义和声明的文件,文件名就是模块名加上.py的后缀,导入一个py文件,解释器解释该py文件,导入一个包,解释器解释该包下的 __init__.py 文件,所 ...

  8. Scikit-Learn模块学习笔记——数据集模块datasets

    scikit-learn 的 datasets 模块包含测试数据相关函数,主要包括三类: datasets.load_*():获取小规模数据集.数据包含在 datasets 里 datasets.fe ...

  9. python学习笔记五 模块上(基础篇)

    模块学习 模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要 ...

随机推荐

  1. 从壹开始微服务 [ DDD ] 之七 ║项目第一次实现 & CQRS初探

    前言 哈喽大家周五好,我们又见面了,感谢大家在这个周五读我的文章,经过了三周的时间,当然每周两篇的速度的情况下,咱们简单说了下DDD领域驱动设计的第一部分,主要包括了,<项目入门DDD架构浅析& ...

  2. 使用chan的时候选择对象还是指针

    使用chan的时候选择对象还是指针 今天在写代码的时候遇到一个问题,在创建一个通道的时候,不确定创建的通道是使用chan A还是chan *A. 思考了一下,觉得这个应该和函数一样是一个值传递还是参数 ...

  3. PhotoPickerDemo【PhotoPicker0.9.8的个性化修改以及使用(内部glide版本号是3.7.0)】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 本Demo使用的是PhotoPicker 0.9.8版本,属于比较旧的版本,里面集成的glide版本号是3.7.0.本篇文章主要是留 ...

  4. 将svg文件化成字体图标的步骤

     一 前提摘要     有一个活就是按照需求在现有的项目中新增几个项目和修改几个项目,是很简单的,但当中遇到了一个小问题,就是tabs中图标选中和被选中的颜色问题,如果是新开发的,目前掌握的有两种办法 ...

  5. 机器学习——随机森林,RandomForestClassifier参数含义详解

    1.随机森林模型 clf = RandomForestClassifier(n_estimators=200, criterion='entropy', max_depth=4) rf_clf = c ...

  6. springboot~@Valid注解对嵌套类型的校验

    @Valid注解可以实现数据的验证,你可以定义实体,在实体的属性上添加校验规则,而在API接收数据时添加@valid关键字,这时你的实体将会开启一个校验的功能,具体的代码如下,是最基本的应用: 实体: ...

  7. HandlerInterceptor拦截实现对PathVariable变量的读取

    Http请求拦截作用 拦截后可以修改请求体 拦截后可以作一些其它统一的操作 问题提出 对于很多时间需要拦截很多Http请求,然后去获取一些参数,这些参数可能是querystring串,也可能是路由上的 ...

  8. 【Python3爬虫】大众点评爬虫(破解CSS反爬)

    本次爬虫的爬取目标是大众点评上的一些店铺的店铺名称.推荐菜和评分信息. 一.页面分析 进入大众点评,然后选择美食(http://www.dianping.com/wuhan/ch10),可以看到一页有 ...

  9. 完美解决phpstudy安装后mysql无法启动(无需删除原数据库,无需更改任何配置,无需更改端口)直接共存

    PHPstudy与原Mysql兼容解决 一.前言 今天学习php,当然是要先安装好运行环境了,phpstyudy是一个运行php的集成环境, 一键安装对新手很友好,与时作为一个新手,便跟着教程安装了p ...

  10. 4.3dotnet watch run「深入浅出ASP.NET Core系列」

    希望给你3-5分钟的碎片化学习,可能是坐地铁.等公交,积少成多,水滴石穿,谢谢关注. dotnet run的麻烦 如果您使用的是vs code进行跨平台开发,那么dotnet watch run对你的 ...