我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python3 标准库概览

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python3 标准库概览

本文基于以下教程:
http://www.runoob.com/python3/python3-stdlib.html

笔记内容:Python3 标准库概览
笔记日期:2017-11-27


<br>

Python3 标准库概览

  • 操作系统接口
  • 文件通配符
  • 获得脚本参数
  • 错误输出重定向和程序终止
  • 字符串正则匹配
  • 数学
  • 访问互联网
  • 日期和时间
  • 数据压缩
  • 性能度量
  • 测试模块

<br>

操作系统接口


os模块提供了不少与操作系统相关联的函数。例如:

>>> import os  # 导入os模块
>>> os.getcwd()    # 此函数返回当前的工作目录
'E:\\Python3.6'
>>> os.chdir('/server/accesslogs')   # 修改当前的工作目录
>>> os.system('mkdir today')   # 执行系统命令 mkdir 
0

建议使用 "import os" 风格而非 "from os import *"。这样可以保证随操作系统不同而有所变化的 os.open() 不会覆盖内置函数 open()。

在使用 os 这样的大型模块时内置的 dir() 和 help() 函数非常有用,例如:

>>> import os
>>> dir(os)  # 以列表的形式返回所有os模块中的函数
['DirEntry', 'F_OK', 'MutableMapping', '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', 'PathLike', 'R_OK', 'SEEK_CUR', 'SEEK_END', 'SEEK_SET', 'TMP_MAX', 'W_OK', 'X_OK', '_Environ', '__all__', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', '_execvpe', '_exists', '_exit', '_fspath', '_get_exports_list', '_putenv', '_unsetenv', '_wrap_close', 'abc', 'abort', 'access', 'altsep', 'chdir', 'chmod', 'close', 'closerange', 'cpu_count', 'curdir', 'defpath', 'device_encoding', 'devnull', 'dup', 'dup2', 'environ', 'errno', 'error', 'execl', 'execle', 'execlp', 'execlpe', 'execv', 'execve', 'execvp', 'execvpe', 'extsep', 'fdopen', 'fsdecode', 'fsencode', 'fspath', 'fstat', 'fsync', 'ftruncate', 'get_exec_path', 'get_handle_inheritable', 'get_inheritable', 'get_terminal_size', 'getcwd', 'getcwdb', 'getenv', 'getlogin', 'getpid', 'getppid', 'isatty', 'kill', 'linesep', 'link', 'listdir', 'lseek', 'lstat', 'makedirs', 'mkdir', 'name', 'open', 'pardir', 'path', 'pathsep', 'pipe', 'popen', 'putenv', 'read', 'readlink', 'remove', 'removedirs', 'rename', 'renames', 'replace', 'rmdir', 'scandir', 'sep', 'set_handle_inheritable', 'set_inheritable', 'spawnl', 'spawnle', 'spawnv', 'spawnve', 'st', 'startfile', 'stat', 'stat_float_times', 'stat_result', 'statvfs_result', 'strerror', 'supports_bytes_environ', 'supports_dir_fd', 'supports_effective_ids', 'supports_fd', 'supports_follow_symlinks', 'symlink', 'sys', 'system', 'terminal_size', 'times', 'times_result', 'truncate', 'umask', 'uname_result', 'unlink', 'urandom', 'utime', 'waitpid', 'walk', 'write']
>>> help(os)  # 返回一个由模块的docstring创建的广泛的手动页面
<returns an extensive manual page created from the module's docstrings>

针对日常的文件和目录管理任务,shutil 模块提供了一个易于使用的高级接口:

>>> import shutil
>>> shutil.copyfile('data.db', 'archive.db')  # 此函数用于拷贝文件
>>> shutil.move('/build/executables', 'installdir')  # 此函数用于移动文件

<br>

文件通配符


glob模块提供了一个函数用于从目录通配符搜索中生成文件列表:

>>> import glob
>>> glob.glob('*.py') # 搜索当前目录下.py的文件
['primes.py', 'random.py', 'quote.py']  # 将这些搜索出来的文件名称生成一个列表

<br>

获得脚本参数


通用工具脚本经常调用命令行参数。这些命令行参数以链表形式存储于 sys 模块的 argv 变量。例如在命令行中执行 "python demo.py one two three" 后可以得到以下输出结果:

>>> import sys
>>> print(sys.argv)
['demo.py', 'one', 'two', 'three']

其实就是说,当我们在Linux系统中执行一个python脚本时,通常会给这个脚本一些参数,例如:

[root@server ~]# python demo.py one two three

然后通过sys 模块的 argv 变量,就可以得到脚本的文件名,和执行时所传递的参数。这和在shell脚本中,使用\$0、\$1、\$2、\$3... 等去获得脚本文件名称和参数值的道理是一样的。例如:

[root@server ~/shellFile]# vim demo.sh
#!/bin/bash
echo "$0,$1,$2,$3"
[root@server ~/shellFile]# sh demo.sh one tow three
demo.sh,one,tow,three
[root@server ~/shellFile]#

<br>

错误输出重定向和程序终止


sys 还有 stdin,stdout 和 stderr 属性,即使在 stdout 被重定向时,后者也可以用于显示警告和错误信息,类似于java中的out和err。

>>> sys.stderr.write('Warning, log file not found starting a new one\n')
Warning, log file not found starting a new one

大多脚本的定向终止都使用 "sys.exit()",类似于shell的exit。代码示例:

#!/usr/bin/python
import sys

for i in range(1,10):
  print(i)
  if i==3:
    sys.exit()

print("done")

运行结果:

[root@server ~/shellFile]# python testExit.py
1
2
3

sys.exit()会终止整个脚本。

<br>

字符串正则匹配


re模块为高级字符串处理提供了正则表达式工具。对于复杂的匹配和处理,正则表达式提供了简洁、优化和快速的解决方案,被称为文本匹配中的”瑞士××ד:

>>> import re
# 检索正则表达式所匹配的字符串,然后生成一个列表
>>> re.findall(r'\bf[a-z]*', 'which foot or hand fell fastest') 
['foot', 'fell', 'fastest']
# 截取正则表达式所匹配的字符串
>>> re.sub(r'(\b[a-z]+) \1', r'\1', 'cat in the the hat') 
'cat in the hat'

如果只需要简单的功能,应该首先考虑字符串的方法,因为它们非常简单,易于阅读和调试,正则表达式可读性差是它的缺点:

>>> 'tea for too'.replace('too', 'two')
'tea for two'

<br>

数学


math模块为浮点运算提供了对底层C语言函数库的访问,因为math模块主要是用来进行数学方面的计算或业务处理的:

>>> import math
>>> math.cos(math.pi / 4) # 返回math.pi / 4的弧度的余弦值,math.pi是圆周率
0.70710678118654757
>>> math.log(1024, 2)  # 返回1024以2为底数的自然对数
10.0

random模块提供了生成随机数的工具:

>>> import random
>>> random.choice(['apple', 'pear', 'banana']) # 此函数可以返回一个列表、元组或字符串的随机项。
'apple'
>>> random.sample(range(100), 10)   # 不重复抽样,也就是不随机重复的值
[30, 83, 16, 4, 8, 81, 41, 50, 18, 33]
>>> random.random()    # 生成一个1以内的浮点类型随机数
0.17970987693706186
>>> random.randrange(6)    # 生成一个6以内的整数类型的随机数
4

<br>

访问互联网


有几个模块用于访问互联网以及处理网络通信协议。其中最简单的两个是用于处理从 urls 接收的数据的 urllib.request 以及用于发送电子邮件的 smtplib:

>>> from urllib.request import urlopen
# urlopen用于模拟浏览器访问网站
>>> for line in urlopen('http://tycho.usno.navy.mil/cgi-bin/timer.pl'):
...     line = line.decode('utf-8')  # 将二进制数据解码为文本。
...     if 'EST' in line or 'EDT' in line:  # 找出东部时间,将其打印出来
...         print(line)

<BR>Nov. 25, 09:43:32 PM EST

>>> import smtplib
>>> server = smtplib.SMTP('localhost')
>>> server.sendmail('soothsayer@example.org', 'jcaesar@example.org',
... """To: jcaesar@example.org
... From: soothsayer@example.org
...
... Beware the Ides of March.
... """)
>>> server.quit()

注意第二个例子需要本地有一个在运行的邮件服务器。

<br>

日期和时间


datetime模块为日期和时间处理同时提供了简单和复杂的方法。

支持日期和时间算法的同时,实现的重点放在更有效的处理和格式化输出。

该模块还支持时区处理:

>>> from datetime import date
>>> now = date.today() # 拿出今天的日期
>>> now
datetime.date(2017, 11, 27)
# 格式化此日期格式
>>> now.strftime("%m-%d-%y. %d %b %Y is a %A on the %d day of %B.")
'11-27-17. 27 Nov 2017 is a Monday on the 27 day of November.'

>>> # 支持按照日历日期计算
>>> birthday = date(1964, 7, 31)
>>> age = now - birthday
>>> age.days  # 打印1964-7-31到2017-11-27过了多少天
19477

关于表示时间的字符:

  • %Y 表示四位的年
  • %y 表示两位的年
  • %m 表示两位的月
  • %d 表示两位的日期
  • %b 表示月份的缩写
  • %A 表示星期几
  • %B 表示几月份

<br>

数据压缩


以下模块直接支持通用的数据打包和压缩格式:zlib,gzip,bz2,zipfile,以及 tarfile。

>>> import zlib
>>> s = b'witch which has which witches wrist watch'
>>> len(s)
41
>>> t = zlib.compress(s)  # 以zlib格式将字符串进行压缩
>>> len(t)  # 压缩后的长度
37
>>> zlib.decompress(t)  # 解压缩
b'witch which has which witches wrist watch'
# 得出s的crc32校检值,crc是一种数据错误检查技术
>>> zlib.crc32(s)
226805979

<br>

性能度量


有些用户对了解解决同一问题的不同方法之间的性能差异很感兴趣。Python 提供了一个度量工具,为这些问题提供了直接答案。

例如,使用元组封装和拆封来交换元素看起来要比使用传统的方法要诱人的多,timeit 证明了现代的方法更快一些。

from timeit import Timer

print(Timer('t=a; a=b; b=t', 'a=1; b=2').timeit())
print(Timer('a,b = b,a', 'a=1; b=2').timeit())

运行结果:

0.0248861886867416

0.02537090072342609

相对于 timeit 的细粒度,profile 和 pstats 模块提供了针对更大代码块的时间度量工具。

<br>

测试模块


开发高质量软件的方法之一是为每一个函数开发测试代码,并且在开发过程中经常进行测试
doctest模块提供了一个工具,扫描模块并根据程序中内嵌的文档字符串执行测试。
测试构造如同简单的将它的输出结果剪切并粘贴到文档字符串中。
通过用户提供的例子,它强化了文档,允许 doctest 模块确认代码的结果是否与文档一致:

def average(values):

    # Computes the arithmetic mean of a list of numbers.
    # >>> print(average([20, 30, 70]))
    # 40.0

    return sum(values) / len(values)

import doctest
doctest.testmod()   # 自动验证嵌入测试

unittest模块不像 doctest模块那么容易使用,不过它可以在一个独立的文件里提供一个更全面的测试集:

import unittest

class TestStatisticalFunctions(unittest.TestCase):

    def test_average(self):
        self.assertEqual(average([20, 30, 70]), 40.0)
        self.assertEqual(round(average([1, 5, 7]), 1), 4.3)
        self.assertRaises(ZeroDivisionError, average, [])
        self.assertRaises(TypeError, average, 20, 30, 70)

unittest.main() # 从命令行调用所有测试

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python3 标准库概览

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python3 标准库概览

本文基于以下教程:http://www.runoob.com/python3/python3-stdlib.html笔记内容:Python3 标准库概览笔记日期:2017-11-27
Python3 标准库概览操作系统接口文件通配符获
2023-01-31

Python3 标准库:calendar

1.calendarimport calendarprint(calendar.month(2008,8))#某个月print(calendar.calendar(2008))#某年print(calendar.isleap(2008))#
2023-01-30

Python3标准库built-in、

Python3中实现了很多生成器函数,本篇主要介绍built-in、itertools、functools模块中的生成器。本类生成器函数将iterable对象作为参数,在不改变该iterable对象的条件下,返回iterable子集的生成器
2023-01-31

Python3.x标准模块库目录

string:通用字符串操作re:正则表达式操作difflib:差异计算工具textwrap:文本填充unicodedata:Unicode字符数据库stringprep:互联网字符串准备工具readline:GNU按行读取接口rlcomp
2023-01-31

python标准库

Python有一套很有用的标准库(standard library)。标准库会随着Python解释器,一起安装在你的电脑中的。它是Python的一个组成部分。这些标准库是Python为你准备好的利器,可以让编程事半功倍。 我将根据我个人的使
2023-01-31

Python标准库 - subproce

编写Python脚本时, 经常要执行Linux操作系统命令, 如mkdir zzzz. 目前比较推荐的方法是使用subprocess模块.通过该模块的帮助文档, 可看到其主要提供了4个API, 和相应的使用说明.Main API======
2023-01-31

python之标准库

Python的标准安装包括一组模块,称为标准库。10.1 模块>>>emport math>>>math.sin(0)0.010.1.1 模块是程序任何python程序都可以作为模块导入。#hello.pyprint "hello,worl
2023-01-31

Python标准库 - logging

编写代码时, 常要跟踪下其运行过程, 记录日志是常用的方式. 较简单的就是print命令打印到终端, 或通过open函数写入文件. 但随着代码量的增加, 该方式不可控的弊端, 也凸显出来, 这也正是logging模块出现的背景.对于logg
2023-01-31

python标准库--functools

官方相关地址:https://docs.python.org/3.6/library/functools.html 一.简单介绍:        functools模块用于高阶函数:作用于或返回其他函数的函数。一般而言,任何可调用对象都可以
2023-01-30

Python标准库 - re

编写代码时, 经常要匹配特定字符串, 或某个模式的字符串, 一般会借助字符串函数, 或正则表达式完成.对于正则表达式, 有些字符具有特殊含义, 需使用反斜杠字符'\'转义, 使其表示本身含义. 如想匹配字符'\', 却要写成'\\\\',
2023-01-31

探索Web标准的概念和原则

探索Web标准的定义和原则,需要具体代码示例随着互联网的迅猛发展,Web标准成为了网页制作的基石。作为网页设计师或开发者,了解和遵守Web标准能够帮助我们创建出有效、稳定、高效的网页。本文将探索Web标准的定义、原则,并结合具体的代码示例
探索Web标准的概念和原则
2024-01-15

python 标准库简介

操作系统接口os 模块提供了许多与操作系统交互的函数:>>>>>> import os>>> os.getcwd() # Return the current working directory'C:\\Python37'>>>
2023-01-31

python 标准库大全

文本string:通用字符串操作re:正则表达式操作difflib:差异计算工具textwrap:文本填充unicodedata:Unicode字符数据库stringprep:互联网字符串准备工具readline:GNU按行读取接口rlco
2023-01-31

python常用标准库

-------------------系统内建函数-------------------1、字符串str='这是一个字符串数据测试数据'对应str[0]:获取str字符串中下标为0的字符。str[3]:获取str字符串中下标为3的字符。st
2023-01-31

Python3实现常用数据标准化方法

数据标准化是机器学习、数据挖掘中常用的一种方法。包括我自己在做深度学习方面的研究时,数据标准化是最基本的一个步骤。数据标准化主要是应对特征向量中数据很分散的情况,防止小数据被大数据(绝对值)吞并的情况。另外,数据标准化也有加速训练,防止梯度
2023-01-31

Python标准库14 数据库 (sqlite3)

Python自带一个轻量级的关系型数据库SQLite。这一数据库使用SQL语言。SQLite作为后端数据库,可以搭配Python建网站,或者制作有数据存储需求的工具。SQLite还在其它领域有广泛的应用,比如HTML5和移动端。Python
2023-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录