一、日志模块(logging )

日志是一种追踪软件运行时所发生事件的方法

1、简单的日志编写(文件输出)

import logging      # 日志模块

# 日志配置,把日志内容存到文件中
logging.basicConfig(level=logging.ERROR, # 级别修改,注意一定是大写
format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:S', # 指定时间格式
filename='test.log', # 日志内容存到该文件目录下
filemode='w') # 模式,每次开始都刷新重写,如果想要之前的内容就把‘w’改为‘a’ # 日志级别,()里面是日志的内容,可以随意添加
logging.debug('debug message')
logging.info('info message')
logging.warning('warning message')
logging.error('error message')
logging.critical('critical message')

输出:Tue, 05 Mar 2019 16:37:S logging .py[line:16] ERROR error message
Tue, 05 Mar 2019 16:37:S logging .py[line:17] CRITICAL critical message2、文件和屏幕同时输出

import logging

logger = logging.getLogger()

# 创建一个hangler, 用于写入日志文件
fh = logging.FileHandler('test.log') # 文件输出对象 # 再创建一个handler, 用于输出到控制台
ch = logging.StreamHandler() # 屏幕输出对象 formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') fh.setFormatter(formatter) # 文件输出创建一个formatter输出流格式
ch.setFormatter(formatter) logger.addHandler(fh) # logger里面有两种输出对象,文件和屏幕
logger.addHandler(ch) logger.setLevel(logging.WARNING) # 修改输出日志的级别,从DEBUG开始,输出5行,注意全是大写
# 日志等级是从上到下依次升高的,即:DEBUG < INFO < WARNING < ERROR < CRITICAL
logging.debug('debug message')
logging.info('info message')
logging.warning('waring message')
logging.error('error message')
logging.critical('critical message')

输出:

二、os模块

作用:对大量的文件和文件路径进行操作

import os

print(os.getcwd())   # 获取当前工作目录

os.chdir(r'F:\My test\fullstack\week2')  # 改变当前工作目录,加r表示原生字符串,不进行任何转义

print(os.curdir)   # 获取当前目录:‘.’  用一个‘.’ 表示
print(os.pardir) # 获取当前目录的父级目录字符串名:‘..’
os.makedirs('abc') # 创建文件夹,默认创建在当前目录下,如果文件已存在,报错 os.makedirs('abc\\long') # 创建多层目录,用 \\ 隔开
os.mkdir('abc') # 只能生成一个文件
os.mkdir('abc\\long') # 在已经有abc 文件的基础上,再生成一个文件loing os.removedirs('abc\\long') # 删除文件夹(只能删除空文件)先判断long中有没有文件,没有就删除,一层层往外找
os.rmdir('abc') # 删除单级空目录,若目录不为空无法删除 dirs = os.listdir(r'F:\My test\fullstack\week2') # 打印绝对目录里面的所有文件
print(dirs) os.remove('abc\\dff') # 删除dff文件,只能删除文件不能删除文件夹,
os.rename('abc', 'www') # 修改文件(夹)名, abc改为www info = os.stat('.\\www') # 获取文件的详细信息
print(info)
print(info.st_size) # 获取文件大小 print(os.sep) # \ 获取当前系统的路径分割符
q = os.sep # 用q替换分隔符, q是一个变量 # windows里换行符为: \r\n linux里换行符为:\n print(os.pathsep) # 输出用于路径分割文件路径的字符 print(os.name) # 输出字符串当前使用平台 win->'nt'
print(os.system("dir")) # 显示当前目录的内容
print(os.environ) # 获取系统环境变量
print(os.path.abspath('./www')) # 获取文件www的绝对路径 s = os.path.split(r'F:\My test\fullstack\week2\day3\www')
print(s) # 把文件路径和文件名分隔开 s = os.path.dirname('F:\\My test\\fullstack\\week2\\day3')
print(s) # 返回当前文件上一级的文件夹路径 s = os.path.basename('F:\\My test\\fullstack\\week2\\day3')
print(s) # day3 返回文件名,就是 os.path.split(path) 的第二个内容 s = os.path.exists('F:\\My test\\fullstack\\week2\\day3')
print(s) # path存在返回True,不存在返回False s = os.path.isabs('F:\\My test\\fullstack\\week2\\day3')
print(s) # 如果path是绝对路径返回True,否则返回False s = os.path.isfile('F:\\My test\\fullstack\\week2\\day3')
print(s) # 如果path是一个存在的文件返回True,否则返回False s = os.path.isdir('F:\\My test\\fullstack\\week2\\day3')
print(s) # 如果path是一个存在的目录返回True,否则返回False s = os.path.join('F:\\My test\\fullstack\\week2\\day3', 'F:\\My test\\fullstack\\week2\\day4')
print(s) # 路径拼接: F:\My test\fullstack\week2\day4 s = os.path.getatime('F:\\My test\\fullstack\\week2\\day3')
print(s) # 返回path所指向文件或目录的最后存取时间 s = os.path.getmtime('F:\\My test\\fullstack\\week2\\day3')
print(s) # 返回path所指向文件或目录的最后修改时间

三、configparser 模块

作用:用于生成和修改常见的配置文件,通过字典录入
import configparser    

# 所有操作都围绕config对象进行
config = configparser.ConfigParser() # 写入文件
config["DEFAULT"] = {'ServerAliveInterval': '',
'Compression': 'yes',
'CompressionLevel': ''}
# 生成的是字典的形式:DEFAULG 是键,中括号里面是键值,下同 config['bitbucket.org'] = {'User': 'hg'} config['topsecret.server.com'] = {}
topsecret = config['topsecret.server.com']
topsecret['Host Port'] = ''
topsecret['ForwardXll'] = 'no'
config['DEFAULT']['ForwardXll'] = 'yes' with open('example.ini', 'w') as configfile:
config.write(configfile)

输出:

写入的文件还可以读出来:

import configparser    

config = configparser.ConfigParser()    # 所有操作都围绕config对象进行

config.read('example.ini')   # 读配置文件操作
print(config.sections()) # 不能读取默认块儿的内容:['bitbucket.org', 'topsecret.server.com']
print(config.defaults()) # 读取默认块儿DEFAULT里面的信息
print(config['bitbucket.org']['User']) # hg for key in config:
print(key) # 打印所有块儿的名字 for key in config['bitbucket.org']:
print(key) # DEFAULT 是特殊的,打印别的块下的内容它也跟在下面

配置文件的增删改:

config.remove_section('topsecret.server.com')   # 删除块:topsecret.server.com
config.write(open('i.cfg', 'w')) # 无论如何修改都要加这句,下同
print(config.has_section('topsecret.server.com')) # 判断有没有该字符串:False (因为前面删除了) config.set('bitbucket.org', 'user', 'xiaoss') # 修改操作:('块', '键', '要修改的值') config.remove_option('DEFAULT', 'forwardxll') # 删除块下的某个键值对儿:('块', '键值') config.write(open('example.ini', 'w')) # 注意对文件example.ini,是完全清空重新写入,是覆盖,文件名与原来相同

注意:一个文件一旦命名绝对不会被修改,只能重新建立文件写入,修改并不是真正的修改,而是建立新的文件放在对象里面然后覆
盖原来的对象

python 模块学习(二)的更多相关文章

  1. python模块学习(二)

    configparser模块 软件常见文档格式如下: [DEFAULT]ServerAliveInterval = 45Compression = yesCompressionLevel = 9For ...

  2. 【转】Python模块学习 - fnmatch & glob

    [转]Python模块学习 - fnmatch & glob 介绍 fnmatch 和 glob 模块都是用来做字符串匹配文件名的标准库. fnmatch模块 大部分情况下使用字符串匹配查找特 ...

  3. 【目录】Python模块学习系列

    目录:Python模块学习笔记 1.Python模块学习 - Paramiko  - 主机管理 2.Python模块学习 - Fileinput - 读取文件 3.Python模块学习 - Confi ...

  4. Python模块学习filecmp文件比较

    Python模块学习filecmp文件比较 filecmp模块用于比较文件及文件夹的内容,它是一个轻量级的工具,使用非常简单.python标准库还提供了difflib模块用于比较文件的内容.关于dif ...

  5. Python基础学习二

    Python基础学习二 1.编码 utf-8编码:自动将英文保存为1个字符,中文3个字符.ASCll编码被囊括在内. unicode:将所有字符保存为2给字符,容纳了世界上所有的编码. 2.字符串内置 ...

  6. python模块学习第 0000 题

    将你的 QQ 头像(或者微博头像)右上角加上红色的数字,类似于微信未读信息数量那种提示效果. 类似于图中效果: 好可爱>%<! 题目来源:https://github.com/Yixiao ...

  7. Python模块学习:logging 日志记录

    原文出处: DarkBull    许多应用程序中都会有日志模块,用于记录系统在运行过程中的一些关键信息,以便于对系统的运行状况进行跟踪.在.NET平台中,有非常著名的第三方开源日志组件log4net ...

  8. 解惑Python模块学习,该如何着手操作...

    Python模块 晚上和朋友聊天,说到公司要求精兵计划,全员都要有编程能力.然后C.Java.Python-对于零基础入门的,当然是选择Python的人较多了.可朋友说他只是看了简单的语法,可pyth ...

  9. Python模块学习

    6. Modules If you quit from the Python interpreter and enter it again, the definitions you have made ...

  10. 扩展Python模块系列(二)----一个简单的例子

    本节使用一个简单的例子引出Python C/C++ API的详细使用方法.针对的是CPython的解释器. 目标:创建一个Python内建模块test,提供一个功能函数distance, 计算空间中两 ...

随机推荐

  1. NOIp 2014飞扬的小鸟【dp】By cellur925

    题目传送门 放在14年Day1T3的dp题目...应该比较看出来是dp算法吧,因为在本蒟蒻看来求最值的算法不清晰时就是dp了==. 状态还是比较好设计的,考虑到每个情况需要记录下的量:f[i][j]表 ...

  2. python之迷宫BFS

    # @File: maze_queue_bfs from collections import deque maze = [ [1, 1, 1, 1, 1, 1, 1, 1, 1, 1], [1, 0 ...

  3. LCA+树状数组 POJ 2763 Housewife Wind

    题目传送门 题意:两种操作,问u到v的距离,并且u走到了v:把第i条边距离改成w 分析:根据DFS访问顺序,将树处理成链状的,那么回边处理成负权值,那么LCA加上BIT能够知道u到v的距离,BIT存储 ...

  4. Suricata的命令行解释

    见官网 https://suricata.readthedocs.io/en/latest/command-line-options.html root@SELKS:~# suricata Suric ...

  5. input标签属性

    很多时候,我们都用到了很多标签实现输入功能,所以在这里梳理一下. 1.建立一个文本框 <input type="text" name="userName" ...

  6. [转]自定义ASP.NET MVC JsonResult序列化结果

    本文转自:http://blog.163.com/luckcq@yeah/blog/static/17174770720121293437119/ 最近项目中前台页面使用EasyUI的jQuery插件 ...

  7. js中传统事件绑定模拟现代事件处理

    大家都知道,IE中的现代事件绑定(attachEvent)与W3C标准的(addEventListener)相比存在很多问题, 例如:内存泄漏,重复添加事件并触发的时候是倒叙执行等. 下面是用传统事件 ...

  8. laravel如何查找门脸及注入类方法

    门脸模式 通过 config/app.php 查看别名对应类名 Illuminate\Support\Facades\Log ,查看 LoggerInterface 类文件,得:命名空间+接口名 Ps ...

  9. ubuntu4.04服务器添加虚拟主机

    buntu 14.04配置虚拟主机   虚拟主机常用于在一个单独的IP地址上提供多个域名的网站服务.如果有人想在单个VPS的单个IP地址运行多个网站,这是非常有用的.在这个教程中,让我告诉你如何设置在 ...

  10. UVA 1175 Ladies' Choice 女士的选择(稳定婚姻问题,GS算法)

    题意: 给出每个男的心目中的女神排序,给出每个女的心目中的男神排序,即两个n*n的矩阵,一旦任意两个非舞伴的男女同学觉得对方都比现任舞伴要好,他们就会抛弃舞伴而在一起.为了杜绝这种现象,求每个男的最后 ...