Python----Python高级(模块与包,Python基本库)

embedded/2025/1/22 19:42:01/

一、模块

1.1、概念

就是一个包含了Python代码的以.py为后缀的Python文件,可以被其他 Python程序导入和使用,也可以自己独立执行,里面存放着的是一组相关的函 数或者类,比如查看关键字列表时导入的keyword模块。

1.2、作用 

令Python代码的编写不必从零开始,不用重复“造轮子”的过程。

避免了同一模块内的命名重复问题。

方便代码的管理与维护,提高代码的可读性。

1.3、分类 

内置模块:Python解释器自带的标准库模块,可以直接导入使用,比如 keyword、os等,这些模块可直接导入而不需要安装,在所有安装了Python 解释器的电脑上都可以运行且每个py文件都会自动导入builtins模块。

        import builtins

第三方模块:由其他开发者开发且需要通过包管理工具(pip)安装的模块,比 如Numpy、Pandas等库,如果有代码需要放到别的电脑上运行,那么这个电 脑也需要先安装用到的第三方库才可以正常运行。

自定义模块:用户根据需求自己编写的.py文件。 

1.4、内置变量 

可通过dir()查看模块的内置变量

python">import builtins
print(dir(builtins))
'''
['ArithmeticError', 'AssertionError', 'AttributeError', 'BaseException', 
'BaseExceptionGroup', 'BlockingIOError', 'BrokenPipeError', 'BufferError', 
'BytesWarning', 'ChildProcessError', 'ConnectionAbortedError', 'ConnectionError', 
'ConnectionRefusedError', 'ConnectionResetError', 'DeprecationWarning', 'EOFError', 
'Ellipsis', 'EncodingWarning', 'EnvironmentError', 'Exception', 'ExceptionGroup', 
'False', 'FileExistsError', 'FileNotFoundError', 'FloatingPointError', 'FutureWarning', 
'GeneratorExit', 'IOError', 'ImportError', 'ImportWarning', 'IndentationError', 'IndexError', 
'InterruptedError', 'IsADirectoryError', 'KeyError', 'KeyboardInterrupt', 'LookupError', 
'MemoryError', 'ModuleNotFoundError', 'NameError', 'None', 'NotADirectoryError', 
'NotImplemented', 'NotImplementedError', 'OSError', 'OverflowError', 'PendingDeprecationWarning', 
'PermissionError', 'ProcessLookupError', 'RecursionError', 'ReferenceError', 'ResourceWarning', 
'RuntimeError', 'RuntimeWarning', 'StopAsyncIteration', 'StopIteration', 'SyntaxError', 
'SyntaxWarning', 'SystemError', 'SystemExit', 'TabError', 'TimeoutError', 'True', 'TypeError', 
'UnboundLocalError', 'UnicodeDecodeError', 'UnicodeEncodeError', 'UnicodeError', 'UnicodeTranslateError', 
'UnicodeWarning', 'UserWarning', 'ValueError', 'Warning', 'WindowsError', 'ZeroDivisionError', 
'__IPYTHON__', '__build_class__', '__debug__', '__doc__', '__import__', '__loader__', '__name__', 
'__package__', '__spec__', 'abs', 'aiter', 'all', 'anext', 'any', 'ascii', 'bin', 'bool', 'breakpoint', 
'bytearray', 'bytes', 'callable', 'chr', 'classmethod', 'compile', 'complex', 'copyright', 'credits', 
'delattr', 'dict', 'dir', 'display', 'divmod', 'enumerate', 'eval', 'exec', 'execfile', 'filter', 'float', 
'format', 'frozenset', 'get_ipython', 'getattr', 'globals', 'hasattr', 'hash', 'help', 'hex', 'id', 'input', 
'int', 'isinstance', 'issubclass', 'iter', 'len', 'license', 'list', 'locals', 'map', 'max', 'memoryview', 
'min', 'next', 'object', 'oct', 'open', 'ord', 'pow', 'print', 'property', 'range', 'repr', 'reversed', 'round', 
'runfile', 'set', 'setattr', 'slice', 'sorted', 'staticmethod', 'str', 'sum', 'super', 'tuple', 'type', 'vars', 'zip']
'''

__name__:用于确定模块是被直接运行还是被导入到其他模块中。当一个模块被直接运行时,__name__的值是”__main__”,否则为模块的名称

python">print(__name__)#__main__
python">import time
time.__name__#'time'

__doc__:包含模块的说明性文档。

python">import time
print(time.__doc__)
'''
This module provides various functions to manipulate time values.There are two standard representations of time.  One is the number
of seconds since the Epoch, in UTC (a.k.a. GMT).  It may be an integer
or a floating point number (to represent fractions of seconds).
The Epoch is system-defined; on Unix, it is generally January 1st, 1970.
The actual value can be retrieved by calling gmtime(0).The other representation is a tuple of 9 integers giving local time.
The tuple items are:year (including century, e.g. 1998)month (1-12)day (1-31)hours (0-23)minutes (0-59)seconds (0-59)weekday (0-6, Monday is 0)Julian day (day in the year, 1-366)DST (Daylight Savings Time) flag (-1, 0 or 1)
If the DST flag is 0, the time is given in the regular time zone;
if it is 1, the time is given in the DST time zone;
if it is -1, mktime() should guess based on the date and time.
'''

__file__:包含模块的文件路径。

python">import os
print(os.__file__)
# d:\Anaconda3\envs\pythonproject\Lib\os.py

__all__:定义一个模块中的哪些变量、函数或类可以通过from module import *导入时可以用。

python">import os
print(os.__all__)
'''
['altsep', 'curdir', 'pardir', 'sep', 'pathsep', 'linesep', 'defpath', 'name', 'path', 'devnull', 
'SEEK_SET', 'SEEK_CUR', 'SEEK_END', 'fsencode', 'fsdecode', 'get_exec_path', 'fdopen', 'extsep', 
'_exit', 'DirEntry', 'EX_OK', 'F_OK', 'O_APPEND', 'O_BINARY', 'O_CREAT', 'O_EXCL', 'O_NOINHERIT', 
'O_RANDOM', 'O_RDONLY', 'O_RDWR', 'O_SEQUENTIAL', 'O_SHORT_LIVED', 'O_TEMPORARY', 'O_TEXT', 'O_TRUNC', 
'O_WRONLY', 'P_DETACH', 'P_NOWAIT', 'P_NOWAITO', 'P_OVERLAY', 'P_WAIT', 'R_OK', 'TMP_MAX', 
'W_OK', 'X_OK', 'abort', 'access', 'chdir', 'chmod', 'close', 'closerange', 'cpu_count', 'device_encoding', 
'dup', 'dup2', 'environ', 'error', 'execv', 'execve', 'fspath', 'fstat', 'fsync', 
'ftruncate', 'get_blocking', 'get_handle_inheritable', 'get_inheritable', 'get_terminal_size', 'getcwd', 
'getcwdb', 'getlogin', 'getpid', 'getppid', 'isatty', 'kill', 'link', 'listdir', 'listdrives', 
'listmounts', 'listvolumes', 'lseek', 'lstat', 'mkdir', 'open', 'pipe', 'putenv', 'read', 'readlink', 
'remove', 'rename', 'replace', 'rmdir', 'scandir', 'set_blocking', 'set_handle_inheritable', 'set_inheritable', 
'spawnv', 'spawnve', 'startfile', 'stat', 'stat_result', 'statvfs_result', 'strerror', 
'symlink', 'system', 'terminal_size', 'times', 'times_result', 'truncate', 'umask', 'uname_result', 'unlink', 
'unsetenv', 'urandom', 'utime', 'waitpid', 'waitstatus_to_exitcode', 'write', 'makedirs', 
'removedirs', 'renames', 'walk', 'execl', 'execle', 'execlp', 'execlpe', 'execvp', 'execvpe', 
'getenv', 'supports_bytes_environ', 'spawnl', 'spawnle', 'popen']
'''

__package__:包含模块所在的包的名称。

python">import numpy
print(numpy.__package__)#numpy

__dict__:包含模块的全局命名空间。

python">import numpy
print(numpy.__dict__)

1.5、模块导入 

1.5.1、import语句导入

python">import 模块名        #导入一个模块
import 模块1,模块2…   #导入多个模块
import 模块名  as 模块别名   #导入模块并使用新名字

import加载的模块分为四种类型:


        使用python编写的代码.py文件


        已被编译为共享库或DLL的C或C++扩展


        一组模块的包


        使用C编写并链接到python解释器的内置模块 

python">import mathprint(id(math))#2707970757536
print(type(math))#<class 'module'>
print(math.pi)  #3.141592653589793

1.5.2、from…import导入

基本语法格式:

        from 模块名 import 成员1,成员2,…

        尽量避免from 模块名 import *这种写法。*它表示导入模块中所有的不是以下划线_开头的名字都导入到当前位置。 但你不知道你导入什么名字,很有可能会覆盖掉你之前已经定义的名字。而且可读性极其的差。一般生产环境中尽量避免使用,学习时没有关系。 

python">from math import pi,sinprint(sin(pi/2))  #输出1.0

1.5.3、import语句和from...import语句的区别

import导入的是模块。from...import导入的是模块中的函数/类。

import导入的是“文件”,我们要使用该“文件”下的内容,必须前面加“文件名称”。from...import导入的是文件下的“内容”,我们直接使用这些“内容”即可,前面再也不需要加“文件名称”了。 

python">from math import pi,sin
import mathprint(math.sin(math.pi/2))#输出1.0
print(math.pi)#3.141592653589793
print(sin(pi/2))  #输出1.0

二、包

就是一个有层次的文件目录结构,用来更好的组织和管理模块。通俗的说就 是一个目录,里面存放python文件和新的包目录,并且每一个包目录都需要存在 一个__init__.py文件,__init__.py文件可以没有内容,但必须有这个文件。

__init__.py文件的主要作用:

        标识包目录:告诉Python解释器该文件所在的目录应被视为一个包而不是一个普通的目录。如果没有这个文件,可能会无法正常导入包内的模块。

        执行初始化代码:在该文件中也可以存在代码,在调用该包里的模块时,该文件里的代码也会被运行。

        控制包的导入行为:通过__all__来控制哪些模块可以被导入,从而限制包的公开接口,防止不需要的模块导入。

        提供包级别的命名空间:在该文件中定义的变量和函数可以在包的其他模块中共享。

        批量导入模块:在该文件中可以批量导入系统模块或其他模块。 

三、基本的Python库

标准库

        Python拥有一个强大的标准库。Python语言的核心只包含数字、字符串、列表、字典、文件等常见类型和函数,而由Python标准库提供了系统管理、网络通信、文本处理、数据库接口、图形系统、XML处理等额外的功能。

Python标准库的主要功能有:

  1. 文本处理,包含文本格式化、正则表达式匹配、文本差异计算与合并、Unicode支持,二进制数据处理等功能

  2. 文件处理,包含文件操作、创建临时文件、文件压缩与归档、操作配置文件等功能

  3. 操作系统功能,包含线程与进程支持、IO复用、日期与时间处理、调用系统函数、日志(logging)等功能

  4. 网络通信,包含网络套接字,SSL加密通信、异步网络通信等功能

  5. 网络协议,支持HTTP,FTP,SMTP,POP,IMAP,NNTP,XMLRPC等多种网络协议,并提供了编写网络服务器的框架

  6. W3C格式支持,包含HTML,SGML,XML的处理。

  7. 其它功能,包括国际化支持、数学运算、HASH、Tkinter等

3.1、os

模块提供了与操作系统交互的功能,如文件和目录操作。

python">import os  # 获取当前工作目录  
current_directory = os.getcwd()  
print("当前工作目录:", current_directory)  # 列出当前目录中的文件和文件夹  
files = os.listdir(current_directory)  
print("当前目录中的文件和文件夹:", files)  # 创建一个新目录  
os.mkdir('new_directory')  
print("已创建新目录: new_directory")

3.2、sys

模块提供了对Python解释器的访问,允许您与Python的运行环境进行交互。

python">import sys  # 获取Python版本信息  
print("Python版本:", sys.version)  # 获取命令行参数  
print("命令行参数:", sys.argv)  # 退出程序  
# sys.exit("程序结束")

3.3、time

模块提供了时间相关的功能,包括时间延迟、时间戳等。

python">import time  # 获取当前时间戳  
timestamp = time.time()  
print("当前时间戳:", timestamp)  # 暂停程序执行2秒  
print("暂停2秒...")  
time.sleep(2)  
print("继续执行")

3.4、random

模块用于生成随机数和随机选择。

python">import random  # 生成一个0到10之间的随机整数  
random_integer = random.randint(0, 10)  
print("随机整数:", random_integer)  # 从列表中随机选择一个元素  
choices = ['apple', 'banana', 'cherry']  
random_choice = random.choice(choices)  
print("随机选择的水果:", random_choice)

3.5、math

模块提供了数学函数和常量,如三角函数、对数等。

python">import math  # 计算平方根  
sqrt_value = math.sqrt(16)  
print("16的平方根:", sqrt_value)  # 计算圆周率  
pi_value = math.pi  
print("圆周率:", pi_value)  # 计算正弦值  
sine_value = math.sin(math.pi / 2)  
print("sin(π/2):", sine_value)

四、思维导图 

 


http://www.ppmy.cn/embedded/156136.html

相关文章

科技护航:分布式 IO 模块与大型 PLC,稳筑地铁安全防线

在城市的地下脉络中&#xff0c;地铁如灵动的巨龙&#xff0c;承载着无数人的出行需求。保障地铁的稳定安全运行&#xff0c;是城市高效运转的关键&#xff0c;而这背后&#xff0c;分布式 IO 模块与大型 PLC 的默契协作&#xff0c;功不可没。 智慧大脑 大型 PLC&#xff0c;…

springboot使用ssl连接elasticsearch

使用es时ssl证书报错 unable to find valid certification path to requested target 1.依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elasticsearch</artifactId></dependency>2…

解锁辅助驾驶新境界:基于昇腾 AI 异构计算架构 CANN 的应用探秘

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;《AI大模型》 期待您的关注 目录 一、引言 二、CANN 是什么 1. 异构计算与人工智能的关系 2. CANN 的定义和作用 3. CANN 的技…

C++ ——— 模拟实现 vector 类

目录 vector 类的框架 无参数的构造函数 析构函数 获取有效数据个数 获取容量 重载 [] 运算符 可读可写版本 只可读版本 扩容 尾插 实现迭代器 可读可写版本 只可读版本 自定义设置size长度和内容 在任意位置插入 删除任意位置的数据 赋值重载 vector 类的框…

Appium(四)

一、app页面元素定位 1、通过id定位元素: resrouce-id2、通过ClassName定位&#xff1a;classname3、通过AccessibilityId定位&#xff1a;content-desc4、通过AndroidUiAutomator定位5、通过xpath定位xpath、id、class、accessibility id、android uiautomatorUI AutomatorUI自…

python 解读JSON文件,一文搞懂!

一、JSON格式详解 所有 JSON 数据需要包裹在一个花括号中。 {"sites": [{ "name":"maybe" , "url":"www.maybe.com" }, { "name":"google" , "url":"www.google.com" }] } Objec…

《开源与合作:驱动鸿蒙Next系统中人工智能技术创新发展的双引擎》

在当今科技飞速发展的时代&#xff0c;鸿蒙Next系统作为一款具有创新性和前瞻性的操作系统&#xff0c;为人工智能技术的发展提供了广阔的舞台。而开源和合作则是推动鸿蒙Next系统中人工智能技术创新和发展的两大关键引擎。 开源&#xff1a;创新的源泉 代码共享与知识传播&am…

解决 Django 5.1 中的 TemplateSyntaxError 错误

解决 Django 5.1 中的 TemplateSyntaxError 错误 在 Django 开发过程中&#xff0c;我们经常会遇到 TemplateSyntaxError 错误&#xff0c;尤其是在模板文件中使用不被支持或错误的模板标签时。最近&#xff0c;我们遇到的一个常见错误是&#xff1a; Invalid block tag on l…