日志记录模块
日志的几个级别
debug
info
warning
error
critical
级别由低到高,一般默认只显示warning以上级别。
logging.basicConfig(level=logging.DEBUG)
更改默认日志记录级别为DEBUG,此时从debug到critical都会记录。
推荐日志格式
logging.basicConfig(level=logging.DEBUG, format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',datefmt=' %Y/%m/%d %H:%M:%S', filename='myapp.log', filemode='w')
logging.basicConfig(level=logging.DEBUG, format=’%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s’,datefmt=’ %Y/%m/%d %H:%M:%S’, filename=’myapp.log’, filemode=’w’)
os模块
s模块
os.name
如果结果为nt, 则为windows系统,
如果结果为posix, 则为unix系统
os.system(cmd) 纯粹的执行系统命令,但是没有返回结果
result = os.popen(cmd)
result.read() 这样你就可以对reuslt进行控制了
用于区分系统执行命令,
举例如下
import os
print(os.name)
if os.name == "nt":
cmd = "ipconfig"
elif os.name == "posix":
cmd = "ifconfig"
os的基本用法:
补充知识
换行符
windows换行符\n\r linux换行符\n mac \r
random() 函数
.
描述
random() 方法返回随机生成的一个实数,它在[0,1)范围内。
语法
以下是 random() 方法的语法:
import random
random.random()
注意:random()是不能直接访问的,需要导入 random 模块,然后通过 random 静态对象调用该方法。
参数
无
返回值
返回随机生成的一个实数,它在[0,1)范围内。
引用自
应用举例
以下是课堂实例
实现目的:投掷骰子,统计出现次数
import random
print(random.randrange(1, 100, 2))
print(random.sample([1, 2, 3, 4, 5, 6, 7], 2))
class NumberCount(object):
def __init__(self):
self.number1 = 0
self.number2 = 0
self.number3 = 0
self.number4 = 0
self.number5 = 0
self.number6 = 0
def count(self):
for i in range(1, 6001):
number = random.randint(1, 6)
if number == 1:
self.number1 += 1
if number == 2:
self.number2 += 1
if number == 3:
self.number3 += 1
if number == 4:
self.number4 += 1
if number == 5:
self.number5 += 1
if number == 6:
self.number6 += 1
def getResult(self):
print("1出现的次数: {0}".format(self.number1))
print("2出现的次数: {0}".format(self.number2))
print("3出现的次数: {0}".format(self.number3))
print("4出现的次数: {0}".format(self.number4))
print("5出现的次数: {0}".format(self.number5))
print("6出现的次数: {0}".format(self.number6))
if __name__ == "__main__":
numberCount = NumberCount()
numberCount.count()
numberCount.getResult()
后面还讲解了随机验证码生成,没有教学视频,后续查资料补齐代码