@python学习记录
这一关主要讲导入模块问题,一开始的时候我是用pycharm2018社区版和python3.6,导入模块总是失败,也查了网上的解决办法,点file-settings之后添加不行,创建虚拟环境再添加也不行,实在没有办法两个都卸了从头开始安装python3.8,pycharm2020社区版,中间省略配置问题,可喜的是最后弄好了,可以正常添加模块。
回到正题
类是封装属性和方法,模块则是变量、函数、类都可以封装,调用模块的时候可以直接导入
##模块文件(story.py)
sentence = '从前有坐山,'
def mountain():
print('山里有座庙,')
class Temple:
sentence = '庙里有个老和尚,'
def reading(self):
print('在讲一个长长的故事。')
_____________________________
#调用
import story #第一种导入整个模块
import story as s #第二种为模块取一个简单的名字
from story import Temple #第三种 导入模块的指定部分,这里是类
#第一种调用
print(story.sentence)#调用属性
a = story.Temple()#模块中的类实例化
print(a.sentence)#实例化以后调用类方法,此时不加模块名
#第二种调用,将模块名story用s代替
print(s.sentence)
a = s.Temple()
print(a.sentence)
#第三种调用,导入模块的一部分调用时不需要加模块名,容易忘记是导入的模块
a = Temple()#直接实例化,没加模块名
print(a.sentence)
a.reading()
程序入口
即在程序文件中有多个函数,首先执行的函数就叫入口函数,是程序运行开始的地方。
if__name__==‘main’ 通常用于指定入口函数,当此语句出现在直接运行的程序文件时,此语句后的命令优先运行,当此语句出现在被导入的模块中时,此语句后的命令不被运行。
在Shell里import某个模块后,模块名.__file__查找模块的文件路径,打开就可以看到模块内定义的变量,属性,函数,类
import csv
csv.__file__
#输出路径
'D:\\Python\\Python38\\lib\\csv.py'
print(dir(csv))
#输出csv的变量、函数、类、类方法
['Dialect', 'DictReader', 'DictWriter', 'Error', 'QUOTE_ALL', 'QUOTE_MINIMAL', 'QUOTE_NONE', 'QUOTE_NONNUMERIC', 'Sniffer', 'StringIO', '_Dialect', '__all__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '__version__', 'excel', 'excel_tab', 'field_size_limit', 'get_dialect', 'list_dialects', 're', 'reader', 'register_dialect', 'unix_dialect', 'unregister_dialect', 'writer']
#前后有——的是系统相关函数,全英文名的是需要关注的
16.1时间日期的格式化
# 第一行:必不可少的调用模块。
import time
input("欢迎使用“时间管理器”!请按回车继续。")
while True:
task_name = input('请输入任务名:')
task_time = int(input('你觉得自己至少可以专注这个任务多少分钟?输入 N 分钟'))
input('此次任务信息:\n我要完成的任务:%s\n我至少要专注:%d分钟\n按回车开始专注:' % (task_name, task_time))
# 下面应该要有两行代码,自动记录可以计算以及可以打印的开始时间。
tick = time.time()
print('开始时间:' + time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(tick)))
# 这里可以加一个倒计时,实时显示还剩多少时间,可参考左侧提供的资料。代码量大概有5行。
print('倒计时开始')
for i in range(1, task_time*60): #迭代器不能是int,float
if i < task_time * 60:
print('倒计时:' + time.strftime('%M:%S', time.localtime(task_time*60-i)))
time.sleep(1)
else:
break
task_status = input('请在任务完成后按输入y:')
if task_status == 'y':
# 下面应该要有两行代码,自动记录可以计算以及可以打印的结束时间。
finish = time.time()
print('结束时间::' + time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(finish)))
actual_time = time.strftime('%H:%M:%S', time.localtime(finish-tick))
# 有了自动记录的始末时间后,记录的代码也需要随之改变。
with open('timelog2.txt','a', encoding = 'utf-8') as f:
f.write(task_name + ' 的预计时长为:' + str(task_time) + '分钟\n')
f.write(task_name + ' 的实际时长为:' + str(actual_time) + '分钟\n')
again = input('建立一个新任务请按 y, 退出时间日志记录器请按 q:')
if again == 'q':
break
else:
print('抱歉,你的输入有误。请重启时间记录器。')
print('愿被你善待的时光,予你美好的回赠。')
16.2
os 模块的替换文件名
import os
list_test = ['一弦一柱思华年。\n','只是当时已惘然。\n']
with open ('poem3.txt','r') as f:
lines = f.readlines()
with open('poem_new.txt','w') as new:
for line in lines:
if line in list_test:
new.write('____________。\n')
else:
new.write(line)
os.replace('poem_new.txt', 'poem3.txt')