Fork me on GitHub

Python学习笔记之内置模块

os

os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cd
os.curdir  返回当前目录: ('.')
os.pardir  获取当前目录的父目录字符串名:('..')
os.makedirs('dirname1/dirname2')    可生成多层递归目录
os.removedirs('dirname1')    若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname')    生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname')    删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname')    列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove()  删除一个文件
os.rename("oldname","newname")  重命名文件/目录
os.stat('path/filename')  获取文件/目录信息
os.sep    输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
os.linesep    输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
os.pathsep    输出用于分割文件路径的字符串
os.name    输出字符串指示当前使用平台。win->'nt'; Linux->'posix'
os.system("bash command")  运行shell命令,直接显示
os.environ  获取系统环境变量
os.path.abspath(path)  返回path规范化的绝对路径
os.path.split(path)  将path分割成目录和文件名二元组返回
os.path.dirname(path)  返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path)  返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path)  如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path)  如果path是绝对路径,返回True
os.path.isfile(path)  如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path)  如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]])  将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path)  返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path)  返回path所指向的文件或者目录的最后修改时间

 

 

sys

sys.argv           命令行参数List,第一个元素是程序本身路径
sys.exit(n)        退出程序,正常退出时exit(0)
sys.version        获取Python解释程序的版本信息
sys.maxint         最大的Int值
sys.path           返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
sys.platform       返回操作系统平台名称

 

系统命令

# os 模块
os.system(cmd)  在子终端运行系统命令,不能获取命令执行后的返回信息以及执行返回的状态

os.popen(cmd)  不仅执行命令而且返回执行后的信息对象(常用于需要获取执行命令后的返回信息)

# commands模块
getoutput    获取执行命令后的返回信息
getstatus    获取执行命令的状态值(执行命令成功返回数值0,否则返回非0)
getstatusoutput    获取执行命令的状态值以及返回信息

# subprocess模块
subprocess.Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=false)
    
    参数bufsize:指定缓冲。我到现在还不清楚这个参数的具体含义,望各个大牛指点。
    
    参数executable用于指定可执行程序。一般情况下我们通过args参数来设置所要运行的程序。如果将参数shell设为 True,executable将指定程序使用的shell。在windows平台下,默认的shell由COMSPEC环境变量来指定。
    
    参数stdin, stdout, stderr分别表示程序的标准输入、输出、错误句柄。他们可以是PIPE,文件描述符或文件对象,也可以设置为None,表示从父进程继承。
    
    参数preexec_fn只在Unix平台下有效,用于指定一个可执行对象(callable object),它将在子进程运行之前被调用。
    
    参数Close_sfs:在windows平台下,如果close_fds被设置为True,则新创建的子进程将不会继承父进程的输入、输出、错误管 道。我们不能将close_fds设置为True同时重定向子进程的标准输入、输出与错误(stdin, stdout, stderr)。
    
    如果参数shell设为true,程序将通过shell来执行。
    
    参数cwd用于设置子进程的当前目录。
    
    参数env是字典类型,用于指定子进程的环境变量。如果env = None,子进程的环境变量将从父进程中继承。
    
    参数Universal_newlines:不同操作系统下,文本的换行符是不一样的。如:windows下用’/r/n’表示换,而Linux下用 ‘/n’。如果将此参数设置为True,Python统一把这些换行符当作’/n’来处理。
    
    参数startupinfo与createionflags只在windows下用效,它们将被传递给底层的CreateProcess()函数,用 于设置子进程的一些属性,如:主窗口的外观,进程的优先级等等。
    
    subprocess.PIPE
    在创建Popen对象时,subprocess.PIPE可以初始化stdin, stdout或stderr参数,表示与子进程通信的标准流。
    
    subprocess.STDOUT
    创建Popen对象时,用于初始化stderr参数,表示将错误通过标准输出流输出。
    
    Popen的方法:
    Popen.poll() 
    用于检查子进程是否已经结束。设置并返回returncode属性。
    
    Popen.wait() 
    等待子进程结束。设置并返回returncode属性。
    
    Popen.communicate(input=None)
    与子进程进行交互。向stdin发送数据,或从stdout和stderr中读取数据。可选参数input指定发送到子进程的参数。 Communicate()返回一个元组:(stdoutdata, stderrdata)。注意:如果希望通过进程的stdin向其发送数据,在创建Popen对象的时候,参数stdin必须被设置为PIPE。同样,如 果希望从stdout和stderr获取数据,必须将stdout和stderr设置为PIPE。
    
    Popen.send_signal(signal) 
    向子进程发送信号。
    
    Popen.terminate()
    停止(stop)子进程。在windows平台下,该方法将调用Windows API TerminateProcess()来结束子进程。
    
    Popen.kill()
    杀死子进程。
    
    Popen.stdin 
    如果在创建Popen对象是,参数stdin被设置为PIPE,Popen.stdin将返回一个文件对象用于策子进程发送指令。否则返回None。
    
    Popen.stdout 
    如果在创建Popen对象是,参数stdout被设置为PIPE,Popen.stdout将返回一个文件对象用于策子进程发送指令。否则返回 None。
    
    Popen.stderr 
    如果在创建Popen对象是,参数stdout被设置为PIPE,Popen.stdout将返回一个文件对象用于策子进程发送指令。否则返回 None。
    
    Popen.pid 
    获取子进程的进程ID。
    
    Popen.returncode 
    获取进程的返回值。如果进程还没有结束,返回None

 

ConfigParser

# INI 格式配置文件的完整语法

NI文件由节、键、值组成。  

节 
    [section]  

参数(键=值) 
    name=value

注解 
    注解使用分号表示(;)。在分号后面的文字,直到该行结尾都全部为注解

********************************
【ConfigParser】

读取

read(filename) 读取ini文件内容
sections() 获取所有的section,并以列表的形式返回
options(sections) 获取指定section的所有option
get(section,option) 获取section中option的值,返回为string类型
写入

set( section, option, value) 对section中的option进行更新

**************示例******************
#!/usr/bin/python3
# coding:utf-8
from __future__ import print_function
import configparser
import os
'''
Created on 2017-10-19
@author: luting
Project:基础类ReadConfig,封装读取配置文件ini的公用方法,
定义get_value等函数方法。
'''



class ReadConfig:
    def __init__(self):
        self.config_path = os.path.split(os.path.realpath(__file__))[0]

    def get_values(self, sections, options):
        """
        读取ini文件
        :param sections: ini中的节
        :param options: ini中的键
        :return: 返回section中的option的值(返回string类型)
        """
        config_ini_path = os.path.join(self.config_path, 'config.ini')
        config = configparser.ConfigParser()
        config.read(config_ini_path)
        return config.get(sections, options)

if __name__ == '__main__':
    read_ini = ReadConfig()
    print(read_ini.get_values('Mysql', 'user'))

 

logging

默认情况下,logging将日志打印到屏幕,日志级别为WARNING;
日志级别大小关系为:CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET,当然也可以自己定义日志级别。

日志级别

logging.basicConfig函数各参数:
filename: 指定日志文件名
filemode: 和file函数意义相同,指定日志文件的打开模式,'w'或'a'
format: 指定输出的格式和内容,format可以输出很多有用信息,如上例所示:
 %(levelno)s: 打印日志级别的数值
 %(levelname)s: 打印日志级别名称
 %(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
 %(filename)s: 打印当前执行程序名
 %(funcName)s: 打印日志的当前函数
 %(lineno)d: 打印日志的当前行号
 %(asctime)s: 打印日志的时间
 %(thread)d: 打印线程ID
 %(threadName)s: 打印线程名称
 %(process)d: 打印进程ID
 %(message)s: 打印日志信息
datefmt: 指定时间格式,同time.strftime()
level: 设置日志级别,默认为logging.WARNING
stream: 指定将日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略



# 第一步,创建一个logger
  logger = logging.getLogger()
  logger.setLevel(logging.INFO)    # Log等级总开关

# 第二步,创建一个handler,用于写入日志文件  
  logfile = './log/logger.txt'
  fh = logging.FileHandler(logfile, mode='w')
  fh.setLevel(logging.DEBUG)   # 输出到file的log等级的开关

# 第三步,再创建一个handler,用于输出到控制台
  ch = logging.StreamHandler()
  ch.setLevel(logging.WARNING)   # 输出到console的log等级的开关

# 第四步,定义handler的输出格式
  formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
  fh.setFormatter(formatter)
  ch.setFormatter(formatter)

# 第五步,将logger添加到handler里面
  logger.addHandler(fh)
  logger.addHandler(ch)

# 第六步,日志
  logger.debug('this is a logger debug message')
  logger.info('this is a logger info message')
  logger.warning('this is a logger warning message')
  logger.error('this is a logger error message')
  logger.critical('this is a logger critical message')  


****************示例**************** #!/usr/bin/python3 # coding:utf-8 from __future__ import print_function import logging import time import os from config import global_parameters ''' Created on 2017-10-19 @author: luting Project:基础类Log,输出测试日志 ''' day = time.strftime('%Y-%m-%d', time.localtime(time.time())) log_path = global_parameters.log_path + "\\" + day if not os.path.isdir(log_path): os.makedirs(log_path) class Log: def __init__(self): self.log_name = os.path.join(log_path, '{0}.log'.format(time.strftime('%Y-%m-%d-%H_%M_%S'))) def console(self, level, message): logger = logging.getLogger(__name__) logger.setLevel(logging.DEBUG) fh = logging.FileHandler(self.log_name, 'a', encoding='utf-8') fh.setLevel(logging.DEBUG) ch = logging.StreamHandler() ch.setLevel(logging.DEBUG) formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') fh.setFormatter(formatter) ch.setFormatter(formatter) logger.addHandler(fh) logger.addHandler(ch) if level == 'info': logger.info(message) elif level == 'debug': logger.debug(message) elif level == 'warning': logger.warning(message) elif level == 'error': logger.error(message) logger.removeHandler(ch) logger.removeHandler(fh) fh.close() def debug(self, message): self.console('debug', message) def info(self, message): self.console('info', message) def warning(self, message): self.console('warning', message) def error(self, message): self.console('error', message) if __name__ == '__main__': log = Log() # log.debug('此处有一个靓仔') # log.error('宇宙无敌测试仔') log.error('一枚测试仔')

 

time

#!/usr/bin/env python3
# _*_ coding:utf-8 _*_

import time

# 当前时间戳
print(time.time())

# 获取当前时间
print(time.localtime(time.time()))
'''
struct_time元组。这种结构具有如下属性
0    tm_year    2008
1    tm_mon    112
2    tm_mday    131
3    tm_hour    023
4    tm_min    059
5    tm_sec    061 (60或61 是闰秒)
6    tm_wday    0到6 (0是周一)
7    tm_yday    一年中的第几天,1366
8    tm_isdst    是否为夏令时,值有:1(夏令时)、0(不是夏令时)、-1(未知),默认 -1
'''

# 格式化时间
print(time.asctime(time.localtime(time.time())))

# 格式化日期
print(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()))
'''
python中时间日期格式化符号:
%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 当前时区的名称
%% %号本身
'''

# 获取某月日历
import calendar
print('本月日历为:\n %s' % calendar.month(2017, 12))



-----------------------------------------------------------------------------------------------

1、time.time():返回当前时间的时间戳

2、time.localtime( [secs] ) 
  将一个时间戳转换为当前时区的struct_time,即时间数组格式的时间 
  参数:

      sec – 转换为time.struct_time类型的对象的秒数

        如果secs参数未提供,则以当前时间为准(即会默认调用time.time())。 

3、time.gmtime([secs]) 
    将一个时间戳转换为UTC时区的struct_time 
  time.gmtime() 函数将一个时间戳转换为UTC时区(0时区)的struct_time,可选的参数sec表示从1970-1-1 00:00:00以来的秒数。其默认值为time.time(),函数返回time.struct_time类型的对象。(struct_time是在time模块中定义的表示时间的对象)。 
如果secs参数未提供,则以当前时间为准      

  参数:

  • sec – 转换为time.struct_time类型的对象的秒数

4、time.mktime(t):将一个struct_time转化为时间戳 
time.mktime() 函数执行与gmtime(), localtime()相反的操作,它接收struct_time对象作为参数,返回用秒数表示时间的浮点数。 
如果输入的值不是一个合法的时间,将触发 OverflowError 或 ValueError。 

参数

  • t – 结构化的时间或者完整的9位元组元素

5、time.sleep(secs):线程推迟指定的时间运行 
线程睡眠指定时间,单位为妙。

 

6、time.clock() 
这个函数, 函数以浮点数计算的秒数返回当前的CPU时间。用来衡量不同程序的耗时,比time.time()更有用。在不同的系统上含义不同。在NUix系统上,它返回的是“进程时间”,它是用妙表示的浮点数(时间戳)。而在Windows中,第一次调用,返回的是进程运行时实际时间。而第二次之后的调用是自第一次调用以后到现在的运行时间。 
返回值 
该函数有两个功能:

  • (1)在第一次调用的时候,返回的是程序运行的实际时间;
  • (2)第二次之后的调用,返回的是自第一次调用后,到这次调用的时间间隔在win32系统下,这个函数返回的是真实时间(wall time),而在Unix/Linux下返回的是CPU时间。

 

7、time.asctime( [t] ) 
把一个表示时间的元组或者struct_time表示为 ‘Sun Aug 23 14:31:59 2015’ 这种形式。如果没有给参数,会将time.localtime()作为参数传入。 
参数:

  • t – 9个元素的元组或者通过函数 gmtime() 或 localtime() 返回的时间值

 

8、time.ctime([secs]) 
把一个时间戳(按秒计算的浮点数)转化为time.asctime()的形式。如果为指定参数,将会默认使用time.time()作为参数。它的作用相当于time.asctime(time.localtime(secs)) 
参数:

  • sec – 要转换为字符串时间的秒数

 

9、time.strftime( format [, t] ) 
返回字符串表示的当地时间。 
把一个代表时间的元组或者struct_time(如由time.localtime()和time.gmtime()返回)转化为格式化的时间字符串,格式由参数format决定。如果未指定,将传入time.localtime()。如果元组中任何一个元素越界,就会抛出ValueError的异常。函数返回的是一个可读表示的本地时间的字符串。 
参数:

  • format:格式化字符串
  • t :可选的参数是一个struct_time对象

 

10、time.strptime(string[,format]) 
将格式字符串转化成struct_time. 
该函数是time.strftime()函数的逆操作。time strptime() 函数根据指定的格式把一个时间字符串解析为时间元组。所以函数返回的是struct_time对象。 
参数:

  • string :时间字符串
  • format:格式化字符串

 

datetime

import datetime

# 获取当前日期时间
print(datetime.datetime.now())

# 格式化
print(datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"))

# date加减
print((datetime.datetime.now() - datetime.timedelta(days=5)).strftime("%Y-%m-%d %H:%M:%S"))

 

posted @ 2017-12-18 18:00  未凉残念浮生若梦  阅读(298)  评论(0编辑  收藏  举报