Python time、datetime、os、random、sys、hashlib、json、shutil、logging、paramiko、subprocess、ConfigParser、xml、shelve模块的使用
文章目录:
1. time & datetime模块
2. os模块
3. random模块
4. sys模块
5. hashlib模块
6. json模块
7. shutil模块
8. logging模块
9. paramiko模块
10. subprocess模块
11. ConfigParser模块
12. xml处理模块
13. shelve模块
1.time & datetime模块:
- #_*_coding:utf-8_*_
- import time
- import datetime
- print(time.clock()) #返回处理器时间,3.3开始已废弃
- print(time.process_time()) #返回处理器时间,3.3开始已废弃
- print(time.time()) #返回当前系统时间戳
- print(time.ctime()) #输出Tue Jan 26 18:23:48 2016 ,当前系统时间
- print(time.ctime(time.time()-86640)) #将时间戳转为字符串格式
- print(time.gmtime(time.time()-86640)) #将时间戳转换成struct_time格式
- print(time.localtime(time.time()-86640)) #将时间戳转换成struct_time格式,但返回 的本地时间
- print(time.mktime(time.localtime())) #与time.localtime()功能相反,将struct_time格式转回成时间戳格式
- #time.sleep(4) #sleep
- print(time.strftime("%Y-%m-%d %H:%M:%S",time.gmtime()) ) #将struct_time格式转成指定的字符串格式
- print(time.strptime("2016-01-28","%Y-%m-%d") ) #将字符串格式转换成struct_time格式
- #datetime module
- print(datetime.date.today()) #输出格式 2016-01-26
- print(datetime.date.fromtimestamp(time.time()-864400) ) #2016-01-16 将时间戳转成日期格式
- current_time = datetime.datetime.now() #
- print(current_time) #输出2016-01-26 19:04:30.335935
- print(current_time.timetuple()) #返回struct_time格式
- #datetime.replace([year[, month[, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]]]])
- print(current_time.replace(2014,9,12)) #输出2014-09-12 19:06:24.074900,返回当前时间,但指定的值将被替换
- str_to_date = datetime.datetime.strptime("21/11/06 16:30", "%d/%m/%y %H:%M") #将字符串转换成日期格式
- new_date = datetime.datetime.now() + datetime.timedelta(days=10) #比现在加10天
- new_date = datetime.datetime.now() + datetime.timedelta(days=-10) #比现在减10天
- new_date = datetime.datetime.now() + datetime.timedelta(hours=-10) #比现在减10小时
- new_date = datetime.datetime.now() + datetime.timedelta(seconds=120) #比现在+120s
- print(new_date)
2.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所指向的文件或者目录的最后修改时间
3.random模块:
- import random
- print random.random()
- print random.randint(1,2)
- print random.randrange(1,10)
用其生成随机验证码:
- import random
- checkcode = ''
- for i in range(4):
- current = random.randrange(0,4)
- if current != i:
- temp = chr(random.randint(65,90))
- else:
- temp = random.randint(0,9)
- checkcode += str(temp)
- print checkcode
4.sys模块:
- sys.argv 命令行参数List,第一个元素是程序本身路径
- sys.exit(n) 退出程序,正常退出时exit(0)
- sys.version 获取Python解释程序的版本信息
- sys.maxint 最大的Int值
- sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
- sys.platform 返回操作系统平台名称
- sys.stdout.write('please:')
- val = sys.stdin.readline()[:-1]
5.hashlib模块:
用于加密相关的操作,代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5算法:
- import hashlib
- # ######## md5 ########
- hash = hashlib.md5()
- hash.update('admin')
- print hash.hexdigest()
- # ######## sha1 ########
- hash = hashlib.sha1()
- hash.update('admin')
- print hash.hexdigest()
- # ######## sha256 ########
- hash = hashlib.sha256()
- hash.update('admin')
- print hash.hexdigest()
- # ######## sha384 ########
- hash = hashlib.sha384()
- hash.update('admin')
- print hash.hexdigest()
- # ######## sha512 ########
- hash = hashlib.sha512()
- hash.update('admin')
- print hash.hexdigest()
以上加密算法虽然非常厉害,但时候存在缺陷,即:通过撞库可以反解。所以,有必要对加密算法中添加自定义key再来做加密。
- import hashlib
- # ######## md5 ########
- hash = hashlib.md5('898oaFs09f')
- hash.update('admin')
- print hash.hexdigest()
python 还有一个 hmac 模块,它内部对我们创建 key 和 内容 再进行处理然后再加密.
- import hmac
- h = hmac.new('stanley')
- h.update('hello')
- print h.hexdigest()
6.json模块:
序列化:
- import json
- user_info = {
- 'name':username,
- 'password':password,
- }
- f = open('../user_info/user_info.json
反序列化:
- import json
- f = open('./user_info.json','r')
- data = json.loads(f.read())
- print(data,type(data))
- result:
- ({'password': '1', 'name': '2'}, <type 'dict'>)
7.shutil模块:
shutil模块提供了大量的文件高级操作,特别针对文件拷贝和删除,主要功能为目录和文件操作及压缩功能。
- 文件操作:
- shutil.copyfile("oldfile","newfile") #oldfile和newfile都只能是文件
- shutil.copy("oldfile","newfile") #oldfile只能是文件夹,newfile可以是文件也可以是目标目录
- shutil.copytree("olddir","newdir") #olddir和newdir都只能是目录,且newdir必须不存在移动文件(目录)
- shutil.move("oldpos","newpos") #移动文件(目录)
- shutil.rmtree("dir") #删除目录,空目录、有内容的目录都可以删除
- 压缩操作:
- base_name: 压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径,
- 如:www =>保存至当前路径
- 如:/Users/eddy/www =>保存至/Users/eddy/
- format: 压缩包种类,“zip”, “tar”, “bztar”,“gztar”
- root_dir: 要压缩的文件夹路径(默认当前目录)
- owner: 用户,默认当前用户
- group: 组,默认当前组
- logger: 用于记录日志,通常是logging.Logger对象
- #将 /Users/eddy/Downloads/test 下的文件打包放置当前程序目录
- import shutil
- ret = shutil.make_archive("wwwwwwwwww", 'gztar', root_dir='/Users/eddy/Downloads/test')
- #将 /Users/eddy/Downloads/test 下的文件打包放置 /Users/eddy/目录
- import shutil
- ret = shutil.make_archive("/Users/eddy/wwwwwwwwww", 'gztar', root_dir='/Users/eddy/Downloads/test')
- shutil 对压缩包的处理是调用 ZipFile 和 TarFile 两个模块来进行的,详细:
- import zipfile
- # 压缩
- z = zipfile.ZipFile('laxi.zip', 'w')
- z.write('a.log')
- z.write('data.data')
- z.close()
- # 解压
- z = zipfile.ZipFile('laxi.zip', 'r')
- z.extractall()
- z.close()
- zipfile 压缩解压
- import tarfile
- # 压缩
- tar = tarfile.open('your.tar','w')
- tar.add('/Users/eddy/PycharmProjects/bbs2.zip', arcname='bbs2.zip')
- tar.add('/Users/eddy/PycharmProjects/cmdb.zip', arcname='cmdb.zip')
- tar.close()
- # 解压
- tar = tarfile.open('your.tar','r')
- tar.extractall() # 可设置解压地址
- tar.close()
8.logging模块:
用于便捷记录日志且线程安全的模块
(1)简单的将日志打印到屏幕
- import logging
- logging.debug('This is debug message')
- logging.info('This is info message')
- logging.warning('This is warning message')
- 屏幕上打印:
- WARNING:root:This is warning message
(2)通过logging.basicConfig函数对日志的输出格式及方式做相关配置
- import logging
- logging.basicConfig(level=logging.DEBUG,
- format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
- datefmt='%a, %d %b %Y %H:%M:%S',
- filename='myapp.log',
- filemode='w')
- logging.debug('This is debug message')
- logging.info('This is info message')
- logging.warning('This is warning message')
- ./myapp.log文件中内容为:
- Sun, 24 May 2009 21:48:54 demo2.py[line:11] DEBUG This is debug message
- Sun, 24 May 2009 21:48:54 demo2.py[line:12] INFO This is info message
- Sun, 24 May 2009 21:48:54 demo2.py[line:13] WARNING This is warning message
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被忽略
(3)将日志同时输出到文件和屏幕
- import logging
- logging.basicConfig(level=logging.DEBUG,
- format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
- datefmt='%a, %d %b %Y %H:%M:%S',
- filename='myapp.log',
- filemode='w')
- #################################################################################################
- #定义一个StreamHandler,将INFO级别或更高的日志信息打印到标准错误,并将其添加到当前的日志处理对象#
- console = logging.StreamHandler()
- console.setLevel(logging.INFO)
- formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
- console.setFormatter(formatter)
- logging.getLogger('').addHandler(console)
- #################################################################################################
- logging.debug('This is debug message')
- logging.info('This is info message')
- logging.warning('This is warning message')
- 屏幕上打印:
- root : INFO This is info message
- root : WARNING This is warning message
- ./myapp.log文件中内容为:
- Sun, 24 May 2009 21:48:54 demo2.py[line:11] DEBUG This is debug message
- Sun, 24 May 2009 21:48:54 demo2.py[line:12] INFO This is info message
- Sun, 24 May 2009 21:48:54 demo2.py[line:13] WARNING This is warning message
(4)logging之日志回滚
- import logging
- from logging.handlers import RotatingFileHandler
- #################################################################################################
- #定义一个RotatingFileHandler,最多备份5个日志文件,每个日志文件最大10M
- Rthandler = RotatingFileHandler('myapp.log', maxBytes=10*1024*1024,backupCount=5)
- Rthandler.setLevel(logging.INFO)
- formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
- Rthandler.setFormatter(formatter)
- logging.getLogger('').addHandler(Rthandler)
- #################################################################################################
从上例和本例可以看出,logging有一个日志处理的主对象,其它处理方式都是通过addHandler添加进去的。
logging的几种handle方式如下:
logging.StreamHandler: 日志输出到流,可以是sys.stderr、sys.stdout或者文件
logging.FileHandler: 日志输出到文件
日志回滚方式,实际使用时用RotatingFileHandler和TimedRotatingFileHandler
logging.handlers.BaseRotatingHandler
logging.handlers.RotatingFileHandler
logging.handlers.TimedRotatingFileHandler
logging.handlers.SocketHandler: 远程输出日志到TCP/IP sockets
logging.handlers.DatagramHandler: 远程输出日志到UDP sockets
logging.handlers.SMTPHandler: 远程输出日志到邮件地址
logging.handlers.SysLogHandler: 日志输出到syslog
logging.handlers.NTEventLogHandler: 远程输出日志到Windows NT/2000/XP的事件日志
logging.handlers.MemoryHandler: 日志输出到内存中的制定buffer
logging.handlers.HTTPHandler: 通过"GET"或"POST"远程输出到HTTP服务器
9.paramiko模块:
paramiko是一个用于做远程控制的模块,使用该模块可以对远程服务器进行命令或文件操作,值得一说的是,fabric和ansible内部的远程管理就是使用的paramiko来现实。
(1)下载安装:
- # pycrypto,由于 paramiko 模块内部依赖pycrypto,所以先下载安装pycrypto
- # 下载安装 pycrypto
- wget pycrypto-2.6.1.tar.gz
- tar -xvf pycrypto-2.6.1.tar.gz
- cd pycrypto-2.6.1
- python setup.py build
- python setup.py install
- # 进入python环境,导入Crypto检查是否安装成功
- # 下载安装 paramiko
- wget paramiko-1.10.1.tar.gz
- tar -xvf paramiko-1.10.1.tar.gz
- cd paramiko-1.10.1
- python setup.py build
- python setup.py install
- # 进入python环境,导入paramiko检查是否安装成功
(2)执行命令,通过用户名密码连接服务器:
- #!/usr/bin/env python
- #coding:utf-8
- import paramiko
- ssh = paramiko.SSHClient()
- ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
- ssh.connect('192.168.1.108', 22, 'stanley', '123')
- stdin, stdout, stderr = ssh.exec_command('df')
- print stdout.read()
- ssh.close();
(3)上传或下载文件,通过用户名和密码验证:
- import os,sys
- import paramiko
- t = paramiko.Transport(('182.92.219.86',22))
- t.connect(username='stanley',password='123')
- sftp = paramiko.SFTPClient.from_transport(t)
- sftp.put('/tmp/test.py','/tmp/test.py')
- t.close()
- import os,sys
- import paramiko
- t = paramiko.Transport(('182.92.219.86',22))
- t.connect(username='stanley',password='123')
- sftp = paramiko.SFTPClient.from_transport(t)
- sftp.get('/tmp/test.py','/tmp/test2.py')
- t.close()
(4)上传或下载文件,通过密钥验证:
- import paramiko
- pravie_key_path = '/home/auto/.ssh/id_rsa'
- key = paramiko.RSAKey.from_private_key_file(pravie_key_path)
- t = paramiko.Transport(('182.92.219.86',22))
- t.connect(username='stanley',pkey=key)
- sftp = paramiko.SFTPClient.from_transport(t)
- sftp.put('/tmp/test3.py','/tmp/test3.py')
- t.close()
- import paramiko
- pravie_key_path = '/home/auto/.ssh/id_rsa'
- key = paramiko.RSAKey.from_private_key_file(pravie_key_path)
- t = paramiko.Transport(('182.92.219.86',22))
- t.connect(username='stanley',pkey=key)
- sftp = paramiko.SFTPClient.from_transport(t)
- sftp.get('/tmp/test3.py','/tmp/test4.py')
- t.close()
10.subprocess模块:
The subprocess
module allows you to spawn new processes, connect to their input/output/error pipes, and obtain their return codes. This module intends to replace several older modules and functions:
- os.system
- os.spawn*
The recommended approach to invoking subprocesses is to use the run()
function for all use cases it can handle. For more advanced use cases, the underlying Popen
interface can be used directly.
The run()
function was added in Python 3.5; if you need to retain compatibility with older versions, see the Older high-level API section.
subprocess.
run
(args, *, stdin=None, input=None, stdout=None, stderr=None, shell=False, timeout=None, check=False)
Run the command described by args. Wait for command to complete, then return a CompletedProcess
instance.
The arguments shown above are merely the most common ones, described below in Frequently Used Arguments (hence the use of keyword-only notation in the abbreviated signature). The full function signature is largely the same as that of the Popen
constructor - apart from timeout, input and check, all the arguments to this function are passed through to that interface.
This does not capture stdout or stderr by default. To do so, pass PIPE
for the stdout and/or stderr arguments.
The timeout argument is passed to Popen.communicate()
. If the timeout expires, the child process will be killed and waited for. The TimeoutExpired
exception will be re-raised after the child process has terminated.
The input argument is passed to Popen.communicate()
and thus to the subprocess’s stdin. If used it must be a byte sequence, or a string if universal_newlines=True
. When used, the internal Popen
object is automatically created withstdin=PIPE
, and the stdin argument may not be used as well.
If check is True, and the process exits with a non-zero exit code, a CalledProcessError
exception will be raised. Attributes of that exception hold the arguments, the exit code, and stdout and stderr if they were captured.
- >>> subprocess.run(["ls", "-l"]) # doesn't capture output
- CompletedProcess(args=['ls', '-l'], returncode=0)
- >>> subprocess.run("exit 1", shell=True, check=True)
- Traceback (most recent call last):
- ...
- subprocess.CalledProcessError: Command 'exit 1' returned non-zero exit status 1
- >>> subprocess.run(["ls", "-l", "/dev/null"], stdout=subprocess.PIPE)
- CompletedProcess(args=['ls', '-l', '/dev/null'], returncode=0,
- stdout=b'crw-rw-rw- 1 root root 1, 3 Jan 23 16:23 /dev/null\n')
调用subprocess.run(...)是推荐的常用方法,在大多数情况下能满足需求,但如果你可能需要进行一些复杂的与系统的交互的话,你还可以用subprocess.Popen(),语法如下:
- p = subprocess.Popen("find / -size +1000000 -exec ls -shl {} \;",shell=True,stdout=subprocess.PIPE)
- print(p.stdout.read())
可用参数:
- args:shell命令,可以是字符串或者序列类型(如:list,元组)
- bufsize:指定缓冲。0 无缓冲,1 行缓冲,其他 缓冲区大小,负值 系统缓冲
- stdin, stdout, stderr:分别表示程序的标准输入、输出、错误句柄
- preexec_fn:只在Unix平台下有效,用于指定一个可执行对象(callable object),它将在子进程运行之前被调用
- close_sfs:在windows平台下,如果close_fds被设置为True,则新创建的子进程将不会继承父进程的输入、输出、错误管道。
所以不能将close_fds设置为True同时重定向子进程的标准输入、输出与错误(stdin, stdout, stderr)。 - shell:同上
- cwd:用于设置子进程的当前目录
- env:用于指定子进程的环境变量。如果env = None,子进程的环境变量将从父进程中继承。
- universal_newlines:不同系统的换行符不同,True -> 同意使用 \n
- startupinfo与createionflags只在windows下有效
将被传递给底层的CreateProcess()函数,用于设置子进程的一些属性,如:主窗口的外观,进程的优先级等等
终端输入的命令分为两种:
- 输入即可得到输出,如:ifconfig
- 输入进行某环境,依赖再输入,如:python
需要交互的命令示例
- import subprocess
- obj = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
- obj.stdin.write('print 1 \n ')
- obj.stdin.write('print 2 \n ')
- obj.stdin.write('print 3 \n ')
- obj.stdin.write('print 4 \n ')
- out_error_list = obj.communicate(timeout=10)
- print out_error_list
11.ConfigParser模块:
(1)用于生成和修改常见配置文档,当前模块的名称在 python 3.x 版本中变更为 configparser。
看一个好多软件的常见文档格式如下:
- [DEFAULT]
- ServerAliveInterval = 45
- Compression = yes
- CompressionLevel = 9
- ForwardX11 = yes
- [bitbucket.org]
- User = hg
- [topsecret.server.com]
- Port = 50022
- ForwardX11 = no
如果想用python生成一个这样的文档怎么做呢?
- import configparser
- config = configparser.ConfigParser()
- config["DEFAULT"] = {'ServerAliveInterval': '45',
- 'Compression': 'yes',
- 'CompressionLevel': '9'}
- config['bitbucket.org'] = {}
- config['bitbucket.org']['User'] = 'hg'
- config['topsecret.server.com'] = {}
- topsecret = config['topsecret.server.com']
- topsecret['Host Port'] = '50022' # mutates the parser
- topsecret['ForwardX11'] = 'no' # same here
- config['DEFAULT']['ForwardX11'] = 'yes'
- with open('example.ini', 'w') as configfile:
- config.write(configfile)
(2)写完了还可以再读出来:
- >>> import configparser
- >>> config = configparser.ConfigParser()
- >>> config.sections()
- []
- >>> config.read('example.ini')
- ['example.ini']
- >>> config.sections()
- ['bitbucket.org', 'topsecret.server.com']
- >>> 'bitbucket.org' in config
- True
- >>> 'bytebong.com' in config
- False
- >>> config['bitbucket.org']['User']
- 'hg'
- >>> config['DEFAULT']['Compression']
- 'yes'
- >>> topsecret = config['topsecret.server.com']
- >>> topsecret['ForwardX11']
- 'no'
- >>> topsecret['Port']
- '50022'
- >>> for key in config['bitbucket.org']: print(key)
- ...
- user
- compressionlevel
- serveraliveinterval
- compression
- forwardx11
- >>> config['bitbucket.org']['ForwardX11']
- 'yes'
(3)configparser增删改查语法:
- [section1]
- k1 = v1
- k2:v2
- [section2]
- k1 = v1
- import ConfigParser
- config = ConfigParser.ConfigParser()
- config.read('i.cfg')
- # ########## 读 ##########
- #secs = config.sections()
- #print secs
- #options = config.options('group2')
- #print options
- #item_list = config.items('group2')
- #print item_list
- #val = config.get('group1','key')
- #val = config.getint('group1','key')
- # ########## 改写 ##########
- #sec = config.remove_section('group1')
- #config.write(open('i.cfg', "w"))
- #sec = config.has_section('stanley')
- #sec = config.add_section('stanley')
- #config.write(open('i.cfg', "w"))
- #config.set('group2','k1',11111)
- #config.write(open('i.cfg', "w"))
- #config.remove_option('group2','age')
- #config.write(open('i.cfg', "w"))
12.xml处理模块:
(1)xml是实现不同语言或程序之间进行数据交换的协议,跟json差不多,但json使用起来更简单,不过,古时候,在json还没诞生的黑暗年代,大家只能选择用xml呀,至今很多传统公司如金融行业的很多系统的接口还主要是xml。
xml的格式如下,就是通过<>节点来区别数据结构的:
- <?xml version="1.0"?>
- <data>
- <country name="Liechtenstein">
- <rank updated="yes">2</rank>
- <year>2008</year>
- <gdppc>141100</gdppc>
- <neighbor name="Austria" direction="E"/>
- <neighbor name="Switzerland" direction="W"/>
- </country>
- <country name="Singapore">
- <rank updated="yes">5</rank>
- <year>2011</year>
- <gdppc>59900</gdppc>
- <neighbor name="Malaysia" direction="N"/>
- </country>
- <country name="Panama">
- <rank updated="yes">69</rank>
- <year>2011</year>
- <gdppc>13600</gdppc>
- <neighbor name="Costa Rica" direction="W"/>
- <neighbor name="Colombia" direction="E"/>
- </country>
- </data>
(2)xml协议在各个语言里的都 是支持的,在python中可以用以下模块操作xml:
- import xml.etree.ElementTree as ET
- tree = ET.parse("xmltest.xml")
- root = tree.getroot()
- print(root.tag)
- #遍历xml文档
- for child in root:
- print(child.tag, child.attrib)
- for i in child:
- print(i.tag,i.text)
- #只遍历year 节点
- for node in root.iter('year'):
- print(node.tag,node.text)
(3)修改和删除xml文档内容:
- import xml.etree.ElementTree as ET
- tree = ET.parse("xmltest.xml")
- root = tree.getroot()
- #修改
- for node in root.iter('year'):
- new_year = int(node.text) + 1
- node.text = str(new_year)
- node.set("updated","yes")
- tree.write("xmltest.xml")
- #删除node
- for country in root.findall('country'):
- rank = int(country.find('rank').text)
- if rank > 50:
- root.remove(country)
- tree.write('output.xml')
(4)自己创建xml文档:
- import xml.etree.ElementTree as ET
- new_xml = ET.Element("namelist")
- name = ET.SubElement(new_xml,"name",attrib={"enrolled":"yes"})
- age = ET.SubElement(name,"age",attrib={"checked":"no"})
- sex = ET.SubElement(name,"sex")
- sex.text = '33'
- name2 = ET.SubElement(new_xml,"name",attrib={"enrolled":"no"})
- age = ET.SubElement(name2,"age")
- age.text = '19'
- et = ET.ElementTree(new_xml) #生成文档对象
- et.write("test.xml", encoding="utf-8",xml_declaration=True)
- ET.dump(new_xml) #打印生成的格式
13.shelve模块:
shelve模块是一个简单的k,v将内存数据通过文件持久化的模块,可以持久化任何pickle可支持的python数据格式
- import shelve
- d = shelve.open('shelve_test') #打开一个文件
- class Test(object):
- def __init__(self,n):
- self.n = n
- t = Test(123)
- t2 = Test(123334)
- name = ["stanley","rain","test"]
- d["test"] = name #持久化列表
- d["t1"] = t #持久化类
- d["t2"] = t2
- d.close()
Python time、datetime、os、random、sys、hashlib、json、shutil、logging、paramiko、subprocess、ConfigParser、xml、shelve模块的使用的更多相关文章
- Python 常用方法和模块的使用(time & datetime & os &random &sys &shutil)-(六)
1 比较常用的一些方法 1.eval()方法:执行字符串表达式,并返回到字符串. 2.序列化:变量从内存中变成可存储或传输到文件或变量的过程,可以保存当时对象的状态,实现其生命周期的延长,并且需要时可 ...
- PYDay10&11&12&13-常用模块:time|datetime|os|sys|pickle|json|xml|shutil|logging|paramiko、configparser、字符串格式化、py自动全局变量、生成器迭代器
1.py文件自动创建的全局变量 print(vars()) 返回值:{'__name__': '__main__', '__package__': None, '__loader__': <_f ...
- 模块简介:(random)(xml,json,pickle,shelve)(time,datetime)(os,sys)(shutil)(pyYamal,configparser)(hashlib)
Random模块: #!/usr/bin/env python #_*_encoding: utf-8_*_ import random print (random.random()) #0.6445 ...
- python常用模块collections os random sys
Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句. 模块让你能够有逻辑地组织你的 Python 代码段. 把相关的代码 ...
- python 正则,os,sys,hashlib模块
简单的小算法 random随机获取数据 import random def getrandata(num): a=[] i= while i<num: a.append(random.randi ...
- 023--python os、sys、json、pickle、xml模块
一.os模块 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 >>> os.getcwd() 'C:\\Python36' os.chdir(&quo ...
- Python的datetime与Decimal数据进行json序列化的简单说明
我们在Python的json.JSONEncoder类中可以查看Python数据序列化为JSON格式的数据时数据类型的对应关系: class JSONEncoder(object): "&q ...
- python 内置模块之os、sys、shutil
一.OS模块 用于提供系统级别的操作. OS 目录和文件 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirname") 改 ...
- 第九节:os、sys、json、pickle、shelve模块
OS模块: os.getcwd()获取当前路径os.chdir()改变目录os.curdir返回当前目录os.pardir()父目录os.makedirs('a/b/c')创建多层目录os.remov ...
- python基础--常用的模块(collections、time、datetime、random、os、sys、json、pickle)
collection模块: namedtuple:它是一个函数,是用来创建一个自定义的tuple对象的,并且规定了tuple元素的个数,并可以用属性而不是索引来引用tuple的某个元素.所以我们就可以 ...
随机推荐
- Python进阶学习之特殊方法实例详析
Python进阶学习之特殊方法实例详析 最近在学习python,学习到了一个之前没接触过的--特殊方法. 什么是特殊方法?当我们在设计一个类的时候,python中有一个用于初始化的方法$__init_ ...
- Golang- import 导入包的几种方式:点,别名与下划线
包的导入语法 在写Go代码的时候经常用到import这个命令用来导入包文件,看到的方式参考如下: import( "fmt" ) 然后在代码里面可以通过如下的方式调用 fmt.Pr ...
- C++类中的一些细节(重载、重写、覆盖、隐藏,构造函数、析构函数、拷贝构造函数、赋值函数在继承时的一些问题)
1 函数的重载.重写(重定义).函数覆盖及隐藏 其实函数重载与函数重写.函数覆盖和函数隐藏不是一个层面上的概念.前者是同一个类内,或者同一个函数作用域内,同名不同参数列表的函数之间的关系.而后三者是基 ...
- Appium-实战之启动App 获取信息说明
如下为启动 格来云游戏APP启动信息 代码如下: from appium import webdriver caps = {} caps["platformName"] = &qu ...
- KCP - A Fast and Reliable ARQ Protocol
KCP - A Fast and Reliable ARQ Protocol README in English 简介 KCP是一个快速可靠协议,能以比 TCP浪费10%-20%的带宽的代价,换取平均 ...
- Bootstrap+JSP实例学习笔记一.简单的带登录功能的首页
前言 Bootstrap 是流行的 HTML.CSS 和 JS 框架,用于开发响应式布局.移动设备优先的 WEB 项目.源自于twiteer内部的开发框架. 当前(2019-05)最新版本是v3.3. ...
- 注入之Mysql-Getshell思路
- C学习笔记-gcc
GNU CC(通常称为GCC)是GNU项目的编译器,它能够编译C.C++语言编写的程序 gcc的优点 使用gcc,程序员可以控制生成二进制执行文件中调试代码的数量和类型. 和其他编译器一样,gcc也可 ...
- Jira和confluence备份
参考: https://www.cnblogs.com/kevingrace/p/8862531.html JIRA备份和还原: #Jira默认会打开自动备份的功能,备份路径为: /data/atl ...
- [转帖]浪潮信息最大供应商英特尔(Intel):2018 年采购额 145.76 亿元
浪潮信息最大供应商英特尔(Intel):2018 年采购额 145.76 亿元 https://t.cj.sina.com.cn/articles/view/3172142827/bd130eeb01 ...