python-----模块【第一部分】-----
一.hashlib(md5)
import hashlib
obj = hashlib.md5('dsfd'.encode('utf-8'))
obj.update('123'.encode('utf-8'))
print(obj.hexdigest())
二.random
1.randint
#一般配合chr / ord 使用,生成随机验证码
#chr:给定一个int型,把int型转换为ascii码对照表中的字母
#和chr作用相反 #产生一个四位的随机验证码
import random
lis = []
for i in range(4):
v1 = random.randint(65,90)
v2 = chr(v1)
lis.append(v2)
result = ''.join(lis)
print(result)
三.getpass
#在用户输入密码时,影藏密码,在cmd中运行有效
import getpass
val = getpass.getpass('请输入你的密码:')
print(val)
四.os
1.os.path.exists()
#判断一个文件路径是否存在
import os
file_name = 'D:\\python\\code'
if not os.path.exists(file_name):
print('文件路径不存在')#可以创建
else:
print('文件路径已经存在')
2.os.path.dirname()
#返回一个路径的上级一目录
import os
file_name = 'D:\\python\\code'
result = os.path.dirname(file_name)
print(result)
3.os.path.abspath()
#获取一个文件的绝对路径
import os
file_name = 'x.py'
result = os.path.abspath(file_name)
print(result)
4.os.listdir()
#获取当前目录下第一层的所有文件,返回一个列表
import os
file_name = 'D:\\code'
result = os.listdir(file_name)
print(result)
5.os.walk() / os.path.join()
#os.walk 获取当前目录下所有层级的文件
#os.path.join 可以把两个或多个路径拼接起来
import os
file_name = 'D:\\code\\day'
result = os.walk(file_name)
for a,b,c in result:
for i in c:
val = os.path.join(a,i)
print(val)
6.os.makedirs()
#创建新文件夹
import os
os.makedirs('text')
7.os.stat('目标文件').st_size
#获取文件大小
import os
file_size = os.stat('455698.mp4').st_size
print(file_size)
8.os.rename()
#对文件进行重命名
os.rename('db','bb')
五.sys
1.argv
#获取解释器命令行路径
import sys
print(sys.argv)
###############
#接受两个参数,一个参数为文件名,一个为内容,把内容写到文件中
#D:\python\python37 D:\code\x.py 文件名 内容
import sys
data = sys.argv #[ D:\code\x.py , 文件名 , 内容]
file_name = data[1]
file_data = data[2]
with open(file_name, mode = 'w', encoding = 'utf-8') as f:
f.write(file_data)
2.sys.path / sys.path.append()
#默认python导入模块时,去sys.path路径里面挨个查找
#也可以添加查找路径 sys.path.append()
import sys
data = sys.path
for item in data:
print(item)
######添加查找路径
import sys
os.path.append('D:\xxxx\xxx')
六.json
#json是一个特殊的字符串 【python中元祖和集合不能json】
1.dumps / dump
#序列化 把python中的数据类型序列化为字符串
data = [11,'dd','liyang',{'k1':1,'k2':2}]
import json
result = json.dumps(data)
print(result,type(result))
#注意 列表或字典中如有中文,序列化时保留中文显示
2 data = [11,'dd','liyang',{'k1':1,'k2':'张杰'}]
3 import json
4 result = json.dumps(data,ensure_ascii = False)
5 print(result,type(result))
#dump 可以把序列化后的数据写入文件中
import json
data = [11,22,{'k1':1}]
f = open('D:\\code\\x.txt', mode = 'w', encoding = 'utf-8')
json.dump(data,f)
f.close
print('写入成功')
2.loads / load
#反序列化 把一个字符串转换为python中的数据类型
import json
v2 = '["k2",123]'
result = json.loads(v2)
print(result,type(result))
#load 读取文件中被序列化的字符串,并进行反序列化
import json
f = open('D:\\code\\day\\x.txt', mode = 'r', encoding = 'utf-8')
print(json.load(f))
5 f.close
3.pickle
#json,优点:所有语言通用;缺点:只能序列化基本的数据类型 list/dict/int...
#pickle,优点:python中所有的东西都能被他序列化(socket对象);缺点:序列化的内容#只有python认识。\
"""
import pickle
v = {1,2,3,4}
val = pickle.dumps(v)
print(val)
data = pickle.loads(val)
print(data,type(data))
""" """
def f1():
print('f1') v1 = pickle.dumps(f1)
print(v1)
v2 = pickle.loads(v1)
v2()
"""
七.shutil
1.rmtree
#删除文件目录
import shutil
shutil.rmtree('text')
2.move
#重命名
import shutil
shutil.move('ddd','text')
3.make_archive
#压缩文件
import shutil
shutil.make_archive('压缩后的文件名', 'zip', '压缩路径')
4.unpack_archive
#解压缩文件
import shutil
shutil.unpack('要解压压缩件名', extract_dir=r, '要解压到哪里', format = 'zip')
5.##################示例
import os
import shutil
from datetime import datetime
ctime = datetime.now().strftime('%Y-%m-%d-%H-%M-%S') # 1.压缩 text文件夹 zip
# 2.放到到 code 目录(默认不存在)
# 3.将文件解压到D:\x1目录中。
if not os.path.exists('codes'):
os.makedirs('codes')
shutil.make_archive(os.path.join('codes','times'), 'zip', 'D:\\code\\day')
file_name = os.path.join('codes','times')+'.zip'
shutil.unpack_archive(file_name, 'D:\\x1',format = 'zip')
python-----模块【第一部分】-----的更多相关文章
- 孤荷凌寒自学python第七十九天开始写Python的第一个爬虫9并使用pydocx模块将结果写入word文档
孤荷凌寒自学python第七十九天开始写Python的第一个爬虫9 (完整学习过程屏幕记录视频地址在文末) 今天在上一天的基础上继续完成对我的第一个代码程序的书写. 到今天终于完成了对docx模块针对 ...
- 孤荷凌寒自学python第四十六天开始建构自己用起来更顺手一点的Python模块与类尝试第一天
孤荷凌寒自学python第四十六天开始建构自己用起来更顺手一点的Python模块与类,尝试第一天 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 按上一天的规划,这是根据过去我自学其它编程语 ...
- Python学习-第一天-函数和模块的使用
目录 Python学习-第一天总结 print输出的一种简单格式 函数参数之可变参数 模块管理函数 if else语句的单行实现(简洁) 变量作用域 函数书写格式 Python学习-第一天总结 pri ...
- python 学习第五天,python模块
一,Python的模块导入 1,在写python的模块导入之前,先来讲一些Python中的概念性的问题 (1)模块:用来从逻辑上组织Python代码(变量,函数,类,逻辑:实现一个功能),本质是.py ...
- 安装第三方Python模块,增加InfoPi的健壮性
这3个第三方Python模块是可选的,不安装的话InfoPi也可以运行. 但是如果安装了,会增加InfoPi的健壮性. 目录 1.cchardet 自动检测文本编码 2.lxml 用于解析 ...
- Python基础篇【第5篇】: Python模块基础(一)
模块 简介 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就 ...
- Python模块学习
6. Modules If you quit from the Python interpreter and enter it again, the definitions you have made ...
- python-学习笔记之-Day5 双层装饰器 字符串格式化 python模块 递归 生成器 迭代器 序列化
1.双层装饰器 #!/usr/bin/env python # -*- coding: utf-8 -*- # author:zml LOGIN_INFO = False IS_ADMIN = Fal ...
- python 解析XML python模块xml.dom解析xml实例代码
分享下python中使用模块xml.dom解析xml文件的实例代码,学习下python解析xml文件的方法. 原文转自:http://www.jbxue.com/article/16587.html ...
- 编程:C#调用Python模块
当下,C#与Python都是比较热门的计算机编程语言,他们各有优缺点,如果能让他们互相配合工作,那是多么美好的事情,今天我来讲解一下如何利用C#来调用Python. 如果让C#支持调用Python模块 ...
随机推荐
- 爬虫之解析库BeautifulSoup
介绍 Beautiful Soup是python的一个库,最主要的功能是从网页抓取数据.官方解释如下: Beautiful Soup提供一些简单的.python式的函数用来处理导航.搜索.修改分析树等 ...
- java试题复盘——9月26日
5.在 JAVA 编程中, Java 编译器会将 Java 程序转换为(A) A. 字节码 B. 可执行代码 C. 机器代码 D. 以上都不对 解析: 编译器将Java源代码编译成字节码cla ...
- Spring Cloud Eureka(五):Eureka Server 启动流程分析
启用EurekaServer @SpringBootApplication @EnableEurekaServer public class EurekaApplication { public st ...
- form 表单提交数据和文件(fromdata的使用方法)
<!-- 数据和文件一次性提交 --> <form class="form_meren" id="mainForm" name="m ...
- vim 永久显示行号 & 临时显示行号
在linux环境下,vim是常用的代码查看和编辑工具.在程序编译出错时,一般会提示出错的行号,但是用vim打开的代码确不显示行号,错误语句的定位非常不便.那么怎样才能让vim显示代码的行号呢? 1 临 ...
- 解决JAVA单步调试键盘输入被JDB占用的问题
解决JAVA单步调试键盘输入被JDB占用的问题 问题来源: 在完成本周任务时,编写的代码中含有Scanner类,编译及运行过程均正确,但使用JDB单步调试时,运行到输入行无法在JDB内部输入变量值. ...
- java客户端验证https连接(忽略证书验证和证书验证两种方式)
首先根据如下操作生成证书,配置springboot https,生成一个简单的https web服务 https://www.cnblogs.com/qq931399960/p/11889349.ht ...
- Docker 版本的更新和安装
涉及到网址:1.https://docs.docker.com/engine/installation/linux/docker-ce/ubuntu/#prerequisites (官网) ...
- Maven 引入外部依赖
pom.xml 的 dependencies 列表列出了我们的项目需要构建的所有外部依赖项. 要添加依赖项,我们一般是先在 src 文件夹下添加 lib 文件夹,然后将你工程需要的 jar 文件复制到 ...
- springboot之rabbitmq安装与实践
环境:腾讯云centos7 注意:rabbitmq安装插件,可能会报错.本人是主机名的问题,所以修改了主机名. vim /etc/hosts vim /etc/hostname 修改这两个文件,并重启 ...