复习
''' 1.跨文件夹导包 - 不用考虑包的情况下直接导入文件夹(包)下的具体模块 2.__name__: py自执行 '__main__' | py被导入执行 '模块名' 3.包:一系列模块的集合体,通过包内的__init__文件来管理包中所有模块提供给外界的名字 -- 存放所以模块的文件夹名就是包名 4.导包三件事: 1)编译__init__文件的pyc 2)执行__init__文件形成全局名称空间,作为包的全局名称空间,包能直接使用的名字全部是__init__文件中提供的 3)在导包文件中形成一个名字指向包的名称空间 5.包的管理:通过__init__文件来管理,在包中使用相对导入 . 代表当前文件所在目录 .. 代表当前文件所在目录的上一级目录 # .开头的导包语法,from .开头 import 名字,只能存活在包内 '''
今日内容
''' 1.时间模块 2.系统模块 3.项目开发目录规范 4.loggin 5.json '''
time:时间模块
''' 时间戳(timestamp):time.time() 延迟线程的运行:time.sleep(secs) (指定时间戳下的)当前时区时间:time.localtime([secs]) (指定时间戳下的)格林威治时间:time.gmtime([secs]) (指定时间元组下的)格式化时间:time.strftime(fmt时间格式[,tupletime时间元组]) 年:tm_year 月:tm_mon 日:tm_mday 小时:tm_hour 分钟:tm_min 秒:tm_sec 星期(星期从周一开始计算,周一为数字0):tm_wday 一年中的哪天m_yday 是不是夏令时tm_isdst ''' ''' %y 两位数的年份表示(00-99) %Y 四位数的年份表示(000-9999) %m 月份(01-12) %d 月内中的一天(0-31) %H 24小时制小时数(0-23) %I 12小时制小时数(01-12) %M 分钟数(00=59) %S 秒(00-59) %a 本地简化星期名称 %A 本地完整星期名称 %b 本地简化的月份名称 %B 本地完整的月份名称 %c 本地相应的日期表示和时间表示 %j 年内的一天(001-366) %p 本地A.M.或P.M.的等价符 %U 一年中的星期数(00-53)星期天为星期的开始 %w 星期(0-6),星期天为星期的开始 %W 一年中的星期数(00-53)星期一为星期的开始 %x 本地相应的日期表示 %X 本地相应的时间表示 %Z 当前时区的名称 %% %号本身 print(time.time()) # 时间戳,用于数据的唯一标识 print('开始睡觉') # time.sleep(3) # 1557194569.8574438 # 自定义睡觉 old_time = time.time() while time.time() - old_time <= 3: pass print(time.time()) print('醒了') # 当前时区时间 time_obj = time.localtime() print(time_obj) print(time_obj.tm_year) # 格林威治时间 time_obj2 = time.gmtime() print(time_obj2) print(time_obj2.tm_hour) print(time_obj2.tm_wday) # 星期从周一开始计算,周一为数字0 # 1557294569 print(time.localtime(1557094569)) # 将时间戳转化成时间对象 print(time.gmtime(1557094569)) # 格式化时间 # (2019, 5, 6, 6, 16, 9, 0, 126, 0) res = time.strftime("%Y-%m-%d %H:%M:%S") print(res) res = time.strftime("%Y-%m-%d %H:%M:%S", (2008, 8, 8, 8, 8, 8, 0, 0, 0)) print(res) '''
calendar:日历
''' 判断闰年:calendar.isleap(year)能被4整除且如果是整千年百年能被400整除为闰年 查看某年某月日历:calendar.month(year, mouth) 查看某年某月起始星期与当月天数:calendar.monthrange(year, mouth) 查看某年某月某日是星期几:calendar.weekday(year, month, day) print(calendar.isleap(2200)) #False print(calendar.month(2009, 5)) print(calendar.monthrange(2019, 5)) #(2, 31) print(calendar.weekday(2019, 5, 7)) #1 周二 '''
datatime:可以运算的时间
''' 当前时间:datetime.datetime.now() 昨天:当前时间datetime.datetime.now() + 修改的时间量datetime.timedelta(days=-1) 修改时间:datatime_obj.replace(...]) 格式化时间戳:datetime.date.fromtimestamp(timestamp) print(datetime.datetime.year) print(datetime.datetime.day) now_time = datetime.datetime.now() # 当前时间 res = str(now_time) print(res, res[:-7]) days = datetime.timedelta(days=7) # 7天的时间对象 print(days, type(days)) # 修改时间的应用场景:免登陆时间运算 | 会员过期时间 time_obj = now_time + days print(time_obj, type(time_obj)) new_time_obj = time_obj.replace(year=2000, day=1, second=0) print(new_time_obj) print(datetime.date.fromtimestamp(1557094560)) # 2019-05-06 '''
sys:系统
''' 命令行参数List,第一个元素是程序本身路径:sys.argv 退出程序,正常退出时exit(0):sys.exit(n) 获取Python解释程序的版本信息:sys.version 最大int值:sys.maxsize | sys.maxint 环境变量:sys.path 操作系统平台名称:sys.platform '''
os:操作系统
''' 生成单级目录:os.mkdir('dirname') 生成多层目录:os.makedirs('dirname1/.../dirnamen2') 重命名:os.rename("oldname","newname") 工作目录:os.getcwd() 删除单层空目录:os.rmdir('dirname') 移除多层空目录:os.removedirs('dirname1/.../dirnamen') 列举目录下所有资源:os.listdir('dirname') 路径分隔符:os.sep 行终止符:os.linesep 文件分隔符:os.pathsep 操作系统名:os.name 操作系统环境变量:os.environ 执行shell脚本:os.system() '''
os.path:系统路径操作
''' 执行文件的当前路径:__file__ 返回path规范化的绝对路径:os.path.abspath(path) 将path分割成目录和文件名二元组返回:os.path.split(path) 上一级目录:os.path.dirname(path) 最后一级名称:os.path.basename(path) 指定路径是否存在:os.path.exists(path) 是否是绝对路径:os.path.isabs(path) 是否是文件:os.path.isfile(path) 是否是路径:os.path.isdir(path) 路径拼接:os.path.join(path1[, path2[, ...]]) 最后存取时间:os.path.getatime(path) 最后修改时间:os.path.getmtime(path) 目标大小:os.path.getsize(path) ''' ''' normcase函数 在Linux和Mac平台上,该函数会原样返回path,在windows平台上会将路径中所有字符转换为小写,并将所有斜杠转换为饭斜杠。 >>> os.path.normcase('c:/windows\system32\') 'c:\windows\system32\' normpath函数 规范化路径,如..和/ >>> os.path.normpath('c://windows\System32\../Temp/') 'c:\windows\Temp' >>> a='/Users/jieli/test1/\a1/\\aa.py/../..' >>> print(os.path.normpath(a)) /Users/jieli/test1 '''
跨文件夹移动文件
import os import sys BASE_DIR = os.path.dirname(os.path.dirname(__file__)) sys.path.append(BASE_DIR) def move_file(file, folder): if not (os.path.exists(file) and os.path.isfile(file)): print('文件不存在或非法') return False if not os.path.exists(folder): os.makedirs(folder) file_name = os.path.split(file)[1] # file_name = os.path.basename(file) new_file = os.path.join(folder, file_name) with open(file, 'rb') as rf, open(new_file, 'wb') as wf: for line in rf: wf.write(line) os.remove(file) # 将目标文件夹下的目标文件移动到指定文件夹下 file = os.path.join(BASE_DIR, 'part5', 'mm.py') folder = os.path.join(BASE_DIR, 'part6', 'abc') move_file(file, folder)
递归删除的思路
def delete_dir(folder): for path in os.listdir(folder): # 如果path是文件夹 delete_dir(path) # 如果是文件os.remove(path) pass # for走完了代表folder内部删空了,可以删folder
递归遍历打印目标路径中所有的txt文件
def print_txt(folder): if not os.path.exists(folder) or os.path.isfile(folder): return for path in os.listdir(folder): file_path = os.path.join(folder, path) if os.path.isfile(file_path) and file_path.endswith('.txt'): print(path) elif os.path.isdir(file_path): print_txt(file_path) # 递归 target_path = os.path.join(BASE_DIR, 'part6', 'target') print_txt(target_path)
项目开发周期
''' 1.调研 2.需求分析 3.架构师完成项目demo,完成项目架构 4.分工 5.写代码 6.白盒黑盒测试 7.项目审核发布 => 项目 -> 产品 ''' ''' bin: 可执行文件,入口,入口也可以放在项目根目录下 core: 核心代码 db:数据库相关文件 interface:接口 lib:包、模块、第三方文件夹 log:日志 setting:配置 static:静态文件 '''