python 阿狸的进阶之路(6)
常用模块
json
# 序列化
#将内存的数据存到硬盘中,中间的格式,可以被多种语言识别,跨平台交互数据
#json 可以将字典之类的数据类型存到字典中
import json
dic = {"a":1}
res2 = str(dic)
res = json.dumps(dic)
print(res,type(res))
print(res2,type(res2))
#{"a": 1} <class 'str'>
# {'a': 1} <class 'str'>
# python None = null
#json 只识别 "",不识别'' # user= {'name':'zym','age':25}
# with open("ccc.json",'w',encoding='utf-8 ') as f :
# f.write(json.dumps(user))
#
# #一步到位的方法
# json.dump(user,open('ddd.json','w',encoding='utf-8')) # 反序列化
import json
# with open('ddd.json','r',encoding='utf-8') as f1:
# user2 = json.loads(f1.read())
# print(user2,type(user2))
# print(user2["name"]) # 一步到位的方法
# user2 = json.load(open('ddd.json','r',encoding='utf-8'))
# print(user2['name'])
#random 随机模块
import random
print(random.random())
print(random.choice([2,'',[4,5]]))
print(random.randint(1,3))
print(random.randrange(1,3))
print(random.sample([1,2,3,['zy']],3))
print(random.uniform(1,2))
item = [1,3,5,7,9]
random.shuffle(item)
print(item)
#生成随机验证码
def make_code(n):
res = ''
for i in range(n):
b = str(random.randint(0,9))
a = chr(random.randint(65,90))
c =random.choice([a,b])
res +=c
return res print(make_code(6))
文件操作模块shutil
import shutil
shutil.copyfileobj(open('aaa','r'),open('bbb','w')) #将文件内容拷贝到另一个文件中 shutil.copyfile('f1.txt','f2.txt') #拷贝文件内容,无需打开 shutil.copymode('f1.txt','f2.txt') #仅拷贝权限,内容,组,用户均不变,目标文件必须存在 shutil.copystat('f1.txt','f2.txt') #仅拷贝信息,包括:mode bits,mtime,flags,目标文件必须存在 shutil.copy('f1.txt','f2.txt') #拷贝文件和权限,相当于linux cp -a shutil.copy2('f1.txt','f2.txt') #拷贝文件和状态信息 shutil.copytree('folder1', 'folder2', ignore=shutil.ignore_patterns('*.pyc', 'tmp*'))
#目标目录不能存在,注意对folder2目录父级目录要有可写权限,ignore的意思是排除 import shutil shutil.copytree('f1', 'f2', symlinks=True, ignore=shutil.ignore_patterns('*.pyc', 'tmp*'))
#symlinks =True 拷贝成软链接
'''
通常的拷贝都把软连接拷贝成硬链接,即对待软连接来说,创建新的文件
''' #shutil.rmtree(path[, ignore_errors[, onerror]])
#递归的去删除文件
shutil.rmtree('aaaa') ####### linux中的rm -rf命令,及其危险 shutil.move() #递归的移动文件 # shutil.make_archive(base_name, format,...)
#
# 创建压缩包并返回文件路径,例如:zip、tar
#
# 创建压缩包并返回文件路径,例如:zip、tar
#
# base_name: 压缩包的文件名,也可以是压缩包的路径。只是文件名时,则保存至当前目录,否则保存至指定路径,
# 如 data_bak =>保存至当前路径
# 如:/tmp/data_bak =>保存至/tmp/
# format: 压缩包种类,“zip”, “tar”, “bztar”,“gztar”
# root_dir: 要压缩的文件夹路径(默认当前目录)
# owner: 用户,默认当前用户
# group: 组,默认当前组
# logger: 用于记录日志,通常是logging.Logger对象 # 将 /data 下的文件打包放置当前程序目录
# ret = shutil.make_archive("data_bak", 'gztar', root_dir='/data')
# 将 /data下的文件打包放置 /tmp/目录
# ret = shutil.make_archive("/tmp/data_bak", 'gztar', root_dir='/data') # shutil 对压缩包的处理是调用 ZipFile 和 TarFile 两个模块来进行的,详细:
import zipfile
shutil.make_archive('bak','gztar',root_dir=r"你要打包的文件目录") #相当于 tar cvfz bak /root import tarfile
t = tarfile.open('bak.tar.gz') #得到一个对象
t.extractall('你想要解压到的路径')
t.close()
sys模块的进图条
#进度条
# [# ]
# [## ]
# [### ]
# [#### ]
# print('#'*1)
# print('#'*2)
# print('#'*3)
# print('#'*4)
# print('#'*5)
# import sys
# import time
# print('[%s]' %'#')
# print('[%s]' %'#')
# print('[%s]' %'#')
# print('[%s]' %'#')
# print('[%s]' %'#'*10)
# print('[%-15s]'%'###')
# print(('[%%-%ss]' % 50 )%'###')
# print('%s%%' %100)
# print(('[%%-%ss]'% 50 )%'###','%s%%' %100)
# # a percent
#
#
#
#
#
#
#
# while True:
# print(('[%%-%ss]' % 50) % '###', '%s%%' % 100,end='')
# time.sleep(0.05)
#打印不换行,end = '',覆盖打印即将光标返回开头\r
# import time
# def progress(percent,width = 50):
# if percent>1:
# percent = 1
# print(('\r[%%-%ds]'%width)%('#'*int(percent*width)),end='')
#
# recv_size = 0
# total = 10241
#
# while recv_size < total:
# time.sleep(0.1)
# recv_size+=1024
# percent = recv_size/total
# progress(percent) #进度条
print("[%s]" % '#')
print("[%s]" % '##')
print("[%s]" % '###')
#先考虑将[]设置为指定的宽度,由于是左对齐
print("[%-50s]" % '###')
#并且不能写死了
print(('[%%-%ds]' %50)) #[%-50s]
print(('[%%-%ds]' %50) % "###")
print(('[%%-%ds]' %50) % ("#"*30))
#这时候30,50都是可以被替换掉的,既可以被传参
# “#”的数量是根据百分比来的,例如下载包,用包的现在下载的大小除包的总大小,来得到#的数量
#先定义一个函数,用户自定义[]的宽度 import time
def progress(percent,width = 50):
if percent > 1:
percent =1 # 需要进行判断,否则会出现大于100%的情况
show_t = ('[%%-%ds]' %width) % ("#"*int(width*percent)) #\r 将光标移动到开头
print( '\r%s %d%%' %(show_t,int(100*percent)),end='') current_size = 0
total_size = 102410
while current_size < total_size:
time.sleep(0.1) #需要睡眠,要不然看不到打印的效果,因为速度太快
current_size += 1024
percent = current_size/total_size
progress(current_size/total_size)
python 阿狸的进阶之路(6)的更多相关文章
- python 阿狸的进阶之路(9)
tcp传输: 传输需要ack回应,然后才清空缓存,服务端先起来. tcp流式协议,tcp的Nagle的优化算法,会将时间间隔短,数据量小的打包成一个,然后发送给对方,减少发送的次数. UDP协议: 不 ...
- python 阿狸的进阶之路(5)
一.模块 1.什么是模块: 包含了一组功能的python文件,文件名是xxx.py,模块名是module. 可以使用 import module,四个通用的类别: (1)用python编写的py文件 ...
- day3 python 阿狸的进阶之路
函数概念: 1.为什要有函数 组织结构不清晰,可读性差,代码冗余,可扩展性差. 2.什么是函数 具备某一个功能的工具--->函数 事先准备工具->函数的定义 拿来就用. ...
- python 阿狸的进阶之路(8)
异常处理 http://www.cnblogs.com/linhaifeng/articles/6232220.html(转) 网络编程socket http://www.cnblogs.com/li ...
- python 阿狸的进阶之路(7)
面向对象 转自林海峰的博客 http://www.cnblogs.com/linhaifeng/articles/6182264.html 面向对象的理解: 将数据分类,比如学生类.数据有关的函数, ...
- python 阿狸的进阶之路(4)
装饰器 #1.开放封闭原则:对扩展开放,对修改是封闭#2.装饰器:装饰它人的,器指的是任意可调用对象,现在的场景装饰器->函数,被装饰的对象也是->函数#原则:1.不修改被装饰对象的源代码 ...
- Python 从入门到进阶之路(一)
人生苦短,我用 Python. Python 无疑是目前最火的语言之一,在这里就不再夸他的 NB 之处了,本着对计算机编程的浓厚兴趣,便开始了对 Python 的自学之路,并记录下此学习记录的心酸历程 ...
- Python 从入门到进阶之路(七)
之前的文章我们简单介绍了一下 Python 中异常处理,本篇文章我们来看一下 Python 中 is 和 == 的区别及深拷贝和浅拷贝. 我们先来看一下在 Python 中的双等号 == . == 是 ...
- Python 从入门到进阶之路(六)
之前的文章我们简单介绍了一下 Python 的面向对象,本篇文章我们来看一下 Python 中异常处理. 我们在写程序时,有可能会出现程序报错,但是我们想绕过这个错误执行操作.即使我们的程序写的没问题 ...
随机推荐
- host文件的工作原理及应用
host文件的工作原理及应用 Hosts文件是一个用于存储计算机网络中节点信息的文件,它可以将主机名映射到相应的IP地址,实现DNS的功能,它可以由计算机的用户进行控制. 一.Hosts文件基本介绍 ...
- ROS-MikroTik-RouterOS-培训认证各种证书
官方原文: https://mikrotik.com/training/about MikroTik certified training programs MTCNA - MikroTik Cert ...
- sys.modules[__name__]的一个实例
关于sys.modules[__name__]的用法,百度上阅读量比较多得一个帖子是:https://www.cnblogs.com/robinunix/p/8523601.html 对于里面提到的基 ...
- [UE4]Set Array Elem
用一个新元素替换数组中已有的元素. “Size to Fit”:true,表示如果index参数大于数组所有,将会自动扩展数组大小.
- synchronous-request-with-websockets
https://stackoverflow.com/questions/13417000/synchronous-request-with-websockets
- sklearn获得某个参数的不同取值在训练集和测试集上的表现的曲线刻画
from sklearn.svm import SVC from sklearn.datasets import make_classification import numpy as np X,y ...
- SSH框架总结(环境搭建+框架分析+实例源码下载)
一.SSH框架简介 SSH是struts+spring+hibernate集成的web应用程序开源框架. Struts:用来控制的,核心控制器是Controller. Spring:对Struts和H ...
- Shiro Realm
Realm: 在实际应用中,shiro从数据库中获取安全数据(如用户.角色.权限),而不是从ini中,可作为安全数据源 即SecurityManager要验证用户身份,那么它需要从Realm获取相应的 ...
- Markdown画各种图表
并不是所有编辑器都支持,比如博客园这个就不支持... 流程图 st=>start: 开始 op=>operation: 首先按个按钮 op2=>operation: 那你从头开始吧 ...
- for练习.html
<script> 偶数 var str=""; for (var i = 1 ; i <= 100; i++){ if (i%2 == 0) { //str = ...