• 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下为"	
    ",Linux下为"
    "
    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('本月日历为:
     %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"))
  • 相关阅读:
    Eclipse启动Tomcat后无法访问项目
    网络编程-TCP程序实例(简单上传图片)
    网络编程-TCP程序实例(上传文件)
    网络编程-TCP程序实例(文本大写转化器)
    网络编程-TCP程序实例(client端heserver端相互通信)
    网络编程-TCP程序实例(只是发送了数据,在服务器显示)
    网络编程-UDP程序聊天小程序
    网络编程-UDP2
    网络编程-UDP程序实例(基础)
    正则表达式
  • 原文地址:https://www.cnblogs.com/xiaoxiaolulu/p/8058506.html
Copyright © 2020-2023  润新知