[Python] - 模块

文章从简书转入,只因它已不再是以前的简书


image

Life is the art of drawing without an eraser.
生活是一门没有橡皮擦的艺术。


模块简介

  • 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合。而对于一个复杂的功能来,可能需要多个函数才能完成(函数又可以在不同的.py文件中),n个 .py 文件组成的代码集合就称为模块
  • 简而言之:模块,用一砣代码实现了某个功能的代码集合

  • 模块可以被别的程序引入,以使用该模块中的函数等功能


模块分为三种:

  • 内置模块
  • 自定义模块
  • 第三方模块

内置模块

内置模块是Python自带的功能,在使用内置模块相应的功能时,需要【先导入】再【使用】


sys 模块

提供对Python解释器相关的操作:

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

os 模块

提供系统级别的操作

os.getcwd()                 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname")         改变当前脚本工作目录;相当于shell下cd
os.curdir                   返回当前目录: ('.')
os.pardir                   获取当前目录的父目录字符串名:('..')
os.makedirs('dir1/dir2')    可生成多层递归目录
os.removedirs('dirname1')   若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname')         生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname')         删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname')       列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove()                 删除一个文件
os.rename("oldname","new")  重命名文件/目录
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所指向的文件或者目录的最后修改时间

hashlib 模块

用于加密相关的操作,代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法

示例:

import hashlib

# ######## md5 ########
hash = hashlib.md5()
# help(hash.update)
hash.update(bytes('admin', encoding='utf-8'))
print(hash.hexdigest())
print(hash.digest())

######## sha1 ########

hash = hashlib.sha1()
hash.update(bytes('admin', encoding='utf-8'))
print(hash.hexdigest())

# ######## sha256 ########

hash = hashlib.sha256()
hash.update(bytes('admin', encoding='utf-8'))
print(hash.hexdigest())

# ######## sha384 ########

hash = hashlib.sha384()
hash.update(bytes('admin', encoding='utf-8'))
print(hash.hexdigest())

# ######## sha512 ########

hash = hashlib.sha512()
hash.update(bytes('admin', encoding='utf-8'))
print(hash.hexdigest())

以上加密算法虽然依然非常厉害,但时候存在缺陷,即:通过撞库可以反解。所以,有必要对加密算法中添加自定义key再来做加密。

import hashlib

# ######## md5 ########

hash = hashlib.md5(bytes('898oaFs09f',encoding="utf-8"))
hash.update(bytes('admin',encoding="utf-8"))
print(hash.hexdigest())

random 模块

随机模块,获取一个随机数

import random

print(random.random())          # 取 0 到 1 之间随机一个浮点数
print(random.randint(1, 2))     # 取 1 或 2  int 数字随机一个
print(random.randrange(1, 10))  # 取 1 到 10 范围内任意一个数字 

自定义模块

1、定义模块
  • 创建模块文件夹:New –> Python Package # 例如:Day13
  • 在模块内创建文件: New –> Python File # 例如:index.py(后缀.py 自动生成)
  • 在 Python 文件中添加属性和方法 # 例如: str = "Mazy"
2、导入模块

一个模块只会被导入一次,不管你执行了多少次import。这样可以防止导入模块被一遍又一遍地执行。

# 将模块的的搜索路径导入, 使用时必须加该搜索路径
import module
# 从模块中导入一个指定的部分到当前命名空间中
from module.xx.xx import xx
# 跟上一个方式一样,直接可以给导入的部分起一个别名
from module.xx.xx import xx as rename 
# 把一个模块的所有内容全都导入到当前的命名空间
from module.xx.xx import *

示例:
Day13 模块目录下建两个 Python 文件, support.pyindex.py

# Filename: support.py

# func 1
def print_func( name ):
    print ("Hello :", name)
    return

# func 2    
def sayGoodBye():
    print("GoodBye")

# property
str = "Forever 21"

test.py 引入 support 模块:

# Filename: index.py

# 导入模块
import Day13.support
# 现在可以调用模块里包含的函数了
Day13.support.print_func("Mazy")

print("----------------")
# 导入模块的一部分
from Day13.support import sayGoodBye, print_func
print_func("Vivian")
sayGoodBye()

print("----------------")
# 导入模块的所有属性和方法
from Day13.support import *
print_func("Vivian")
sayGoodBye()
print(str)

输出结果

Hello : Mazy
----------------
Hello : Vivian
GoodBye
----------------
GoodBye
Hello : Eric
Forever 21

dir() 函数

内置的函数 dir() 可以找到模块内定义的所有名称

以一个字符串列表的形式返回


第三方模块

第三方模块需要先安装才能使用(推荐使用 pip 安装)

导入和使用方式和自定义模块相似


  • 包是一种管理 Python 模块命名空间的形式,采用”点模块名称”

    • 比如一个模块的名称是 A.B, 那么他表示一个包 A中的子模块 B
  • 目录只有包含一个叫做__init__.py 的文件才会被认作是一个包

  • 包的存在避免了不同库之间的模块重名的情况
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值