百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

【python】常用的内置函数和包(python中的内置函数大全)

myzbx 2025-03-24 18:30 19 浏览

1.os- 操作系统接口

与操作系统交互:

import os
current_directory = os.getcwd()  # Get the current working directory

2.sys- 系统特定参数和函数

访问系统特定的参数和功能:

import sys
sys.exit()  # Exit the script

3.datetime- 基本日期和时间类型

与日期和时间一起工作:

from datetime import datetime
now = datetime.now()  # Current date and time

4.math- 数学函数

执行数学运算:

import math
result = math.sqrt(16)  # Square root

5.random- 生成伪随机数

生成伪随机数:

import random
number = random.randint(1, 10)  # Random integer between 1 and 10

6.json- JSON 编码器和解码器

解析和生成 JSON 数据:

import json
json_string = json.dumps({'name': 'Alice', 'age': 30})  # Dictionary to JSON string

7.re- 正则表达式

使用正则表达式:

import re
match = re.search('Hello', 'Hello, world!')  # Search for 'Hello' in the string

8.urllib- URL 处理模块

与 URL 一起工作:

from urllib.request import urlopen
content = urlopen('http://example.com').read()  # Fetch the content of a webpage

9.http- HTTP 模块

创建 HTTP 服务器和处理 HTTP 请求:

from http.server import HTTPServer, BaseHTTPRequestHandler
class SimpleHTTPRequestHandler(BaseHTTPRequestHandler):    def do_GET(self):
        self.send_response(200)
        self.send_header('Content-type', 'text/html')
        self.end_headers()
        self.wfile.write(b'Python HTTP Server')
        self.wfile.write(b'

Hello from a simple Python HTTP server!

')def run(server_class=HTTPServer, handler_class=SimpleHTTPRequestHandler): server_address = ('', 8000) # Serve on all addresses, port 8000 httpd = server_class(server_address, handler_class) print("Server starting on port 8000...") httpd.serve_forever()if __name__ == '__main__': run()

10.子进程- 子进程管理

启动新进程并连接到它们的输入/输出/错误管道:

import subprocess
subprocess.run(['ls', '-l'])  # Run the 'ls -l' command

11.socket- 低级网络接口

创建网络客户端和服务器:

import socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)  # Create a TCP/IP socket

12.threading- 基于线程的并行

管理代码的并发执行:

import threading
def worker():
    print("Worker thread executing")
thread = threading.Thread(target=worker)
thread.start()

13.多进程- 基于进程的并行

管理并发进程:

from multiprocessing import Process
def worker():
    print("Worker process")
p = Process(target=worker)
p.start()

14.argparse- 命令行选项、参数和子命令解析器

解析命令行参数:

import argparse
parser = argparse.ArgumentParser(description="Process some integers.")
args = parser.parse_args()

15.日志记录- 日志记录功能

记录消息(调试、信息、警告、错误和严重):

import logging
logging.warning('This is a warning message')

16.unittest- 单元测试框架

创建和运行单元测试:

import unittest
class TestStringMethods(unittest.TestCase):
    def test_upper(self):
        self.assertEqual('foo'.upper(), 'FOO')

17.pathlib- 面向对象的文件系统路径

以面向对象的方式处理文件系统路径:

from pathlib import Path
p = Path('.')

18.functools- 高阶函数和可调用对象操作

使用高阶函数和操作在可调用对象上:

from functools import lru_cache
@lru_cache(maxsize=None)
def fib(n):
    if n < 2:
        return n
    return fib(n-1) + fib(n-2)

19.collections- 容器数据类型

使用专用容器数据类型(deque、Counter、OrderedDict 等):

from collections import Counter
c = Counter('hello world')

20.itertools- 创建迭代器的函数,用于高效循环

构建和使用迭代器以实现高效的循环:

import itertools
for combination in itertools.combinations('ABCD', 2):
    print(combination)

21.hashlib- 安全哈希和信息摘要算法

将数据哈希化:

import hashlib
hash_object = hashlib.sha256(b'Hello World')
hex_dig = hash_object.hexdigest()

22.csv- CSV 文件读取和写入

从 CSV 文件中读取和写入:

import csv
with open('file.csv', mode='r') as infile:
    reader = csv.reader(infile)

23.xml.etree.ElementTree- 元素树 XML API

解析和创建 XML 数据:

import xml.etree.ElementTree as ET
tree = ET.parse('file.xml')
root = tree.getroot()

24.sqlite3- SQLite 数据库的 DB-API 2.0 接口

与 SQLite 数据库交互:

import sqlite3
conn = sqlite3.connect('example.db')

25.tkinter- 图形用户界面工具包

创建 GUI 应用程序:

import tkinter as tk
root = tk.Tk()

26.pickle- Python 对象序列化

将 Python 对象结构序列化和反序列化:

import pickle
serialized_obj = pickle.dumps(obj)

27.io- 处理流的核心工具

处理流(类似文件的对象):

from io import StringIO
f = StringIO("some initial text data")

28.时间- 时间访问和转换

访问时间相关功能:

import time
time.sleep(1)  # Sleep for 1 second

29.日历- 通用日历相关功能

与日历一起工作:

import calendar
print(calendar.month(2023, 1))  # Print the calendar for January 2023

30.队列- 一个同步队列类

管理队列,在多线程编程中很有用:

from queue import Queue
q = Queue()

31.shutil- 高级文件操作

执行高级文件操作,如复制和存档:

import shutil
shutil.copyfile('source.txt', 'dest.txt')

32.glob- Unix 风格路径名模式扩展

查找匹配指定模式的文件:

import glob
for file in glob.glob("*.txt"):
    print(file)

33.tempfile- 生成临时文件和目录

创建临时文件和目录:

import tempfile
temp = tempfile.TemporaryFile()

34.bz2- 支持 Bzip2 压缩

使用 bzip2 压缩和解压缩数据:

import bz2
compressed = bz2.compress(b'your data here')

35.gzip- 支持 Gzip 压缩

使用 gzip 压缩解压缩数据:

import gzip
with gzip.open('file.txt.gz', 'wt') as f:
    f.write('your data here')

36.ssl- 用于套接字对象的 TLS/SSL 包装

处理网络套接字的 TLS/SSL 加密和对方认证:

import ssl
ssl.wrap_socket(sock)

37.imaplib- IMAP4 协议客户端

访问和操作 IMAP4 邮件:

import imaplib
mail = imaplib.IMAP4_SSL('imap.example.com')

38.smtp 协议客户端

使用简单邮件传输协议(SMTP)发送邮件:

import smtplib
server = smtplib.SMTP('smtp.example.com', 587)

39.电子邮件- 管理电子邮件消息

管理电子邮件消息,包括 MIME 和其他基于 RFC 2822 的消息文档:

from email.message import EmailMessage
msg = EmailMessage()

40.base64- 基 16,基 32,基 64,基 85 数据编码

使用 Base64 编码和解码数据:

import base64
encoded_data = base64.b64encode(b'data to encode')

41.difflib- 计算差异的辅助工具

比较序列并生成可读的差异:

import difflib
diff = difflib.ndiff('one\ntwo\nthree\n'.splitlines(keepends=True),
                     'ore\ntree\nemu\n'.splitlines(keepends=True))
print(''.join(diff))

42.gettext- 多语言国际化服务

国际化您的 Python 程序:

import gettext
gettext.install('myapp')

43.locale- 国际化服务

访问特定文化数据格式的数据库:

import locale
locale.setlocale(locale.LC_ALL, '')

44.secrets- 生成用于管理秘密的安全随机数

生成用于管理秘密(如令牌或密码)的安全随机数:

import secrets
secure_token = secrets.token_hex(16)

45.uuid- 根据 RFC 4122 的 UUID 对象

生成全局唯一标识符(UUID):

import uuid
unique_id = uuid.uuid4()

46.html- 超文本标记语言支持

处理和操作 HTML 实体:

import html
escaped = html.escape('link')

47.ftplib- FTP 协议客户端

与 FTP 协议交互并传输文件:

from ftplib import FTP
ftp = FTP('ftp.example.com')

48.tarfile- 读取和写入 Tar 归档文件

与 tar 归档文件一起工作,允许您归档和压缩/解压缩:

import tarfile
with tarfile.open('sample.tar.gz', 'w:gz') as tar:
    tar.add('sample.txt')

相关推荐

C语言速成之数组:C语言数据处理的核心武器,你真的玩透了吗?

程序员Feri一名12年+的程序员,做过开发带过团队创过业,擅长Java、鸿蒙、嵌入式、人工智能等开发,专注于程序员成长的那点儿事,希望在成长的路上有你相伴!君志所向,一往无前!数组:C语言数据处理...

ES6史上最全数JS数组方法合集-02-数组操作

数组生成array.ofletres=Array.of(1,2,3)console.log(res)//[1,2,3]下标定位indexOf用于查找数组中是否存在某个值,如果存...

前端性能拉胯?这 8 个 JavaScript 技巧让你的代码飞起来!

在前端开发的江湖里,JavaScript就是我们手中的“绝世宝剑”。但为啥别人用剑就能轻松斩敌,你的代码却总拖后腿,页面加载慢、交互卡顿?别着急!今天带来8个超实用的JavaScript实...

12种JavaScript中最常用的数组操作整理汇总

数组是最常见的数据结构之一,我们需要绝对自信地使用它。在这里,我将列出JavaScript中最重要的几个数组常用操作片段,包括数组长度、替换元素、去重以及许多其他内容。1、数组长度大多数人都知道可...

手把手教你在Webpack写一个Loader

前言有的时候,你可能在从零搭建Webpack项目很熟悉,配置过各种loader,面试官在Webpack方面问你,是否自己实现过一个loader?如果没有去了解过如果去实现,确实有点尴尬,其...

const关键字到底该什么用?(可以用const关键字定义变量吗)

文|守望先生经授权转载自公众号编程珠玑(id:shouwangxiansheng)前言我们都知道使用const关键字限定一个变量为只读,但它是真正意义上的只读吗?实际中又该如何使用const关键字...

“JavaScript变量声明三兄弟,你真的会用吗?

在JavaScript中,var、let和const是声明变量的关键字,它们在作用域、变量提升、重复声明和重新赋值等方面有显著区别。以下是它们的相同点和不同点,并通过代码示例详细说明。一、相同点声明变...

ES6(二)let 和 const(es6 var let const区别)

let命令let和var差不多,只是限制了有效范围。先定义后使用不管是什么编程语言,不管语法是否允许,都要秉承先定义,然后再使用的习惯,这样不会出幺蛾子。以前JavaScript比较随意,...

js 里面 let 和 const的区别(js中的let)

在JavaScript(包括Vue、Node.js、前端脚本等)中,const和let是用于声明变量的两种方式,它们的主要区别如下:constvslet的区别特性constlet是否...

JDK21新特性:Sequenced Collections

SequencedCollectionsJDK21在JEP431提出了有序集合(SequencedCollections)。引入新的接口来表示有序集合。这样的集合都有一个明确的第一个元素、第二个...

动态编程基础——第 2 部分(动态编程是什么)

有两种方法可以使用动态规划来解决问题。在这篇文章中,我们将了解制表法。请参阅我的动态编程基础——第1部分了解记忆方法。记忆制表什么是动态规划?它是一种简单递归的优化技术。它大大减少了解决给定...

Lambda 函数,你真的的了解吗(lambda函数用法)

什么是lambda函数lambda函数是一个匿名函数,这意味着与其他函数不同,它们没有名称。这是一个函数,它添加两个数字,写成一个命名函数,可以按其名称调用它们:defadd(x,y):...

JavaScript 数组操作方法大全(js数组操作的常用方法有哪些)

数组操作是JavaScript中非常重要也非常常用的技巧。本文整理了常用的数组操作方法(包括ES6的map、forEach、every、some、filter、find、from、of等)...

系列专栏(六):解构赋值(解构赋值默认值)

ES6作为新一代JavaScript标准,已正式与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,MozillaWeb开发者博客推出了《ES6InDepth》系列文章。CSDN...

js列表遍历方法解读(js遍历链表)

JavaScript提供了多种遍历数组(或列表)的方法。以下是一些常用的方法及其解读:for循环:vararray=[1,2,3,4,5];for(vari=0;...