大纲:
1、反射
其中的方法:getattr,delattr,setattr,hasattr
__import__()
__import__() 注意事项
2、模块中的特殊变量
__doc__
__cached__
__file__
__name__
__package__
3、sys模块
进度条
4、os模块
反射
利用字符串的形式去对象(模块)中操作(寻找/检查/删除/设置)成员(函数),反射
用到的方法:getattr,delattr,setattr,hasattr
用了一个伪造web框架的路由系统
commons.py文件
commons.py
def login():
print("登录页面")
def logout():
print("退出页面")
def home():
print("主页面")
index.py文件
import commons # 调用commons模块
def run():
url = input("请输入要访问的url:")
"""
url==字符串类型,如果url==“login”
commons.url() 显然,这样是不对的,因为这样执行commons会去他里面找他是否有url这个函数,如果没有,直接报错
利用字符串的形式去对象(模块)中操作(寻找/检查/删除/设置)成员(函数),反射
"""
# setattr()
# delattr()
if hasattr(commons, url): # url==字符串,而现在,url相当于等于一个函数,我们输入的函数,用hasattr去判断是否存在,返回值True或False
func = getattr(commons, url) # 用getattr拿取这个函数,比如url==login,那么也就是说现在(func==commons.login)
func() # 然后我们再来执行以下func,就表示执行commons里面的函数
else:
print("404") # 如果hasattr没有检查到,就执行这句404
if __name__ == '__main__': # __name__ 是当前模块名,当模块被直接运行时模块名为 __main__ 。这句话的意思就是,当模块被直接运行时,以下代码块将被运行,当模块是被导入时,代码块不被运行。
run()
输出:
请输入要访问的url:login
登录页面
从上面可以看出来,我们只能访问一个模块,如果增加一个模块,我们需要去import里面继续添加,当然,python也想过这个问题,所以import也可以传递字符串
一个小小的测试:
#文件:commons.py
def login():
print("登录页面")
def logout():
print("退出页面")
def home():
print("主页面")
#文件:import_test.py
obj = __import__("commons") # 传入字符串
obj.login()
obj.logout()
obj.home()
输出:
登录页面
退出页面
主页面
__import__():
文件:manager.py
def order():
print("订单页面")
文件:commons.py
def login():
print("登录页面")
def logout():
print("退出页面")
def home():
print("主页面")
#文件:index.py
# 有几个bug,比如两个//或者没有/或者模块名乱输入,当然,这只是一个反射的实验
def run():
URL = input("请输入要访问的url:")
imp, url = URL.split("/") # 因为是web浏览,所以以/区分,前面的赋给imp,后面的赋给url
obj = __import__(imp) # 获取到我们输入的模块名
if hasattr(obj, url): # 判断是否有这个模块和函数名,返回True,False
func = getattr(obj, url) # 获取到模块及函数,列入obj=commons,rul=login,那么他们等于commons.login
func()
else:
print("404")
if __name__ == '__main__':
run()
输出:
请输入要访问的url:manager/order
订单页面
请输入要访问的url:commons/home
主页面
__import__()注意事项:

如果出现这种情况该怎么办呢,当然,不要认为(obj = __import__("lib." + string))可以,答案当然是不可以的
解决方法:
string = "commons"
obj = __import__("lib." + string) # 只会返回lib模块,而不会返回lib.commons模块
print(obj)
#输出
# <module 'lib' (namespace)>
string = "commons"
obj = __import__("lib." + string, fromlist=True) # 当我们加上fromlist=True时,就会返回lib.commons
print(obj)
#输出
# <module 'lib.commons' from 'D:\\资料\\常用\\python\\python\\day6\\reflex\\reflex_import_test\\lib\\commons.py'>
模块中的特殊变量
import os
# __doc__
# __cached__
# __file__
# __name__
"""
注释
"""
print(__doc__) # 获取整个py文件中的用"""的注释,(无卵用)
# __cached__ 好像也无卵用
print(__file__) # 返回当前py文件所在的路径
print(os.path.abspath(__file__)) # 获取当前py文件的绝对路径
# os.path.dirname()#返回上一级
print(os.path.dirname(os.path.abspath(__file__))) # 返回当前py文件的上一级的绝对路径
print(__package__) # 返回当前py文件在哪个包里面;print(os.__package__)
# 只有执行当前文件时候,当前文件的特殊变量__name__ == "__main__"
# __name__
def run():
pass
if __name__ == '__main__': # __name__ 是当前模块名,当模块被直接运行时模块名为 __main__ 。这句话的意思就是,当模块被直接运行时,以下代码块将被运行,当模块是被导入时,代码块不被运行。
run()
sys模块
用于提供对Python解释器相关的操作:
""" sys.argv 命令行参数List,第一个元素是程序本身路径 sys.exit(n) 退出程序,正常退出时exit(0) sys.version 获取Python解释程序的版本信息 sys.maxint 最大的Int值 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 sys.platform 返回操作系统平台名称 sys.stdin 输入相关 sys.stdout 输出相关 sys.stderror 错误相关 """
进度条:
import sys
import time
def view_bar(num, total):
rate = num / total
rate_num = int(rate * 100)
r = '\r%s%d%%' % ("=" * num, rate_num)
sys.stdout.write(r)
sys.stdout.flush()
if __name__ == '__main__':
for i in range(0, 100):
time.sleep(0.1)
view_bar(i, 100)
os模块
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd
os.curdir 返回当前目录: ('.')
os.pardir 获取当前目录的父目录字符串名:('..')
os.makedirs('dir1/dir2') 可生成多层递归目录
os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove() 删除一个文件
os.rename("oldname","new") 重命名文件/目录
os.stat('path/filename') 获取文件/目录信息
os.sep 操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
os.linesep 当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
os.pathsep 用于分割文件路径的字符串
os.name 字符串指示当前使用平台。win->'nt'; Linux->'posix'
os.system("bash command") 运行shell命令,直接显示
os.environ 获取系统环境变量
os.path.abspath(path) 返回path规范化的绝对路径
os.path.split(path) 将path分割成目录和文件名二元组返回
os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path) 返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path) 如果path是绝对路径,返回True
os.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path) 返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间