复习
'''
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:静态文件
'''