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

学习python的基础,python最常用的18个内置模块

itomcoil 2025-09-13 01:14 2 浏览

Python 开发中,基础模块(内置模块)是标准库的核心组成部分,直接内置于 Python 解释器中,无需额外安装即可使用。

它们为开发者提供了一系列通用的、跨平台的功能,覆盖了从系统交互到数据处理的广泛需求。以下是常用的18个模块,建议收藏:


1. os(操作系统交互)

  • 用途:操作系统交互(文件/目录管理、环境变量等)。
  • 常用函数os.listdir(), os.mkdir(), os.path.join().
import os
# 列出当前目录下的文件和文件夹
print(os.listdir())

# 创建新目录
os.mkdir("new_folder")

# 拼接路径(跨平台兼容)
path = os.path.join("folder", "subfolder", "file.txt")

2. sys(系统参数)

  • 用途:访问系统参数(命令行参数、Python解释器等)。
  • 常用sys.argv, sys.exit(), sys.path.
import sys

# 获取命令行参数(例如:python script.py arg1 arg2)
print(sys.argv)  # 输出:['script.py', 'arg1', 'arg2']

# 退出程序并返回状态码
sys.exit(0)  # 0 表示正常退出

3. datetime(日期时间)

  • 用途:日期和时间处理。
  • 常用类datetime.datetime, datetime.timedelta.
from datetime import datetime, timedelta

# 当前时间
now = datetime.now()
# 格式化输出:2025-04-17 19:30:00
print(now.strftime("%Y-%m-%d %H:%M:%S"))  

# 时间加减(增加1天)
tomorrow = now + timedelta(days=1)

4. time(时间操作)

  • 用途:时间相关操作(计时、休眠等)。
  • 常用time.sleep(), time.time().
import time

# 计时开始
start = time.time()

# 休眠2秒
time.sleep(2)

# 计算耗时  输出:耗时:2.00秒
print(f"耗时:{time.time() - start:.2f}秒") 

5. math(数学运算)

  • 用途:数学运算(三角函数、对数等)。
  • 常用函数math.sqrt(), math.sin(), math.pi.
import math

# 平方根
print(math.sqrt(16))  # 4.0

# 圆周率
print(math.pi)  # 3.141592653589793

6. random(随机数)

  • 用途:生成随机数和随机操作。
  • 常用random.randint(), random.choice().
import random

# 生成1到10的随机整数
print(random.randint(1, 10))

# 从列表中随机选择一个元素
colors = ["red", "green", "blue"]
print(random.choice(colors))

7. json(JSON处理)

  • 用途:JSON 数据编码与解析。
  • 常用函数json.dumps(), json.loads().
import json

# 将字典转换为JSON字符串
data = {"name": "Alice", "age": 30}
json_str = json.dumps(data)
print(json_str)  # {"name": "Alice", "age": 30}

# 解析JSON字符串
parsed_data = json.loads(json_str)
print(parsed_data["name"])  # Alice

8. re(正则表达式)

  • 用途:正则表达式匹配。
  • 常用re.search(), re.findall(), re.sub().
import re

text = "电话:123-456-7890"

# 查找所有数字
numbers = re.findall(r'\d+', text)
print(numbers)  # ['123', '456', '7890']

# 替换字符
new_text = re.sub(r'-', '', text)
print(new_text)  # 电话:1234567890

9. collections(高级数据结构)

  • 用途:高级数据结构(命名元组、默认字典等)。
  • 常用类collections.defaultdict, collections.Counter.
from collections import defaultdict, Counter

# 默认字典(自动初始化键)
dd = defaultdict(int)
dd["apple"] += 1
print(dd["apple"])  # 1

# 统计元素出现次数
words = ["apple", "banana", "apple"]
counter = Counter(words)
print(counter)  # Counter({'apple': 2, 'banana': 1})

10. argparse(命令行解析)

  • 用途:命令行参数解析。
  • 核心类argparse.ArgumentParser.
import argparse

# 创建解析器
parser = argparse.ArgumentParser(description="示例程序")
parser.add_argument("--input", help="输入文件路径")
parser.add_argument("--verbose", action="store_true", help="详细模式")

# 解析参数
args = parser.parse_args()

if args.verbose:
    print("详细模式已开启")

11. logging(日志记录)

  • 用途:日志记录(调试、错误追踪等)。
  • 常用函数logging.basicConfig(), logging.getLogger().
import logging

# 配置日志格式和级别
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(message)s')

# 记录日志
logging.info("程序启动")
logging.error("发生错误!")

12. subprocess(执行外部命令)

  • 用途:执行外部命令(启动进程、管道交互)。
  • 常用函数subprocess.run().
import subprocess

# 执行系统命令(例如:列出文件)
result = subprocess.run(["ls", "-l"], capture_output=True, text=True)
print(result.stdout)

13. socket(网络通信)

  • 用途:网络通信(TCP/UDP 编程)。
  • 核心类socket.socket.
import socket

# 创建TCP客户端
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
client.connect(("www.httpbin.org", 80))
client.send(b"GET /get HTTP/1.1\r\nHost: httpbin.org\r\n\r\n")
response = client.recv(4096)
print(response.decode())
client.close()

14. urllib(URL请求)

  • 用途:处理 URL 请求(HTTP/HTTPS 客户端)。
  • 子模块urllib.request, urllib.parse.
from urllib.request import urlopen
from urllib.parse import urlencode

# 发送HTTP GET请求
response = urlopen("https://www.httpbin.org/get")
print(response.read().decode()[:100])  # 输出前100个字符

# 编码URL参数
params = urlencode({"q": "python", "page": 2})
print(params)  # q=python&page=2

15. csv(CSV文件读写)

  • 用途:读写 CSV 文件。
  • 常用类csv.reader, csv.writer.
import csv

# 写入CSV文件
with open("data.csv", "w", newline='') as f:
    writer = csv.writer(f)
    writer.writerow(["Name", "Age"])
    writer.writerow(["Alice", 30])

# 读取CSV文件
with open("data.csv", "r") as f:
    reader = csv.reader(f)
    for row in reader:
        print(row)  # ['Name', 'Age'], ['Alice', '30']

16. pickle(对象序列化)

  • 用途:Python 对象序列化与反序列化。
  • 常用函数pickle.dump(), pickle.load().
import pickle

# 序列化对象到文件
data = {"a": 1, "b": 2}
with open("data.pkl", "wb") as f:
    pickle.dump(data, f)

# 反序列化
with open("data.pkl", "rb") as f:
    loaded_data = pickle.load(f)
print(loaded_data)  # {'a': 1, 'b': 2}

17. sqlite3(SQLite数据库)

  • 用途:操作 SQLite 数据库。
  • 核心类sqlite3.Connection, sqlite3.Cursor.
import sqlite3

# 连接数据库并创建表
conn = sqlite3.connect("test.db")
cursor = conn.cursor()
sql = "CREATE TABLE IF NOT EXISTS users (id INTEGER PRIMARY KEY, name TEXT)"
cursor.execute(sql)

# 插入数据
cursor.execute("INSERT INTO users (name) VALUES (?)", ("Alice",))
conn.commit()

# 查询数据
cursor.execute("SELECT * FROM users")
print(cursor.fetchall())  # [(1, 'Alice')]
conn.close()

18. hashlib(哈希算法)

  • 用途:哈希算法(MD5、SHA256 等)。
  • 常用函数hashlib.md5(), hashlib.sha256().
import hashlib

# 计算字符串的MD5哈希值
text = "Hello, World!"
md5 = hashlib.md5(text.encode()).hexdigest()
print(md5)  # 65a8e27d8879283831b664bd8b7f0ad4

# 计算文件的SHA256
with open("file.txt", "rb") as f:
    sha256 = hashlib.sha256(f.read()).hexdigest()
print(sha256)

使用场景示例

  • 数据处理json, csv, pickle, collections.
  • 系统脚本os, sys, argparse, subprocess.
  • 网络编程socket, urllib.
  • 工具开发logging, datetime, random.

总结

Python 基础模块是开发者的“瑞士军刀”,覆盖了日常开发中的高频需求。

  • 快速解决 80% 的常见问题(如文件操作、数据处理)。
  • 写出更简洁、高效、可维护的代码。
  • 为学习更复杂的框架和库(如 Django、NumPy)打下坚实基础。

相关推荐

python数据分析中你必须知道的陷阱和技巧

数据分析是一门既有趣又有挑战的技能,它可以帮助我们从海量的数据中提取有价值的信息,为决策提供支持。但是,数据分析也不是一件轻松的事情,它需要我们掌握一定的编程、统计、可视化等知识,同时也要注意避免一些...

python常见五大坑及避坑指南_python解决什么问题

python是一门非常流行和强大的编程语言,但是也有一些容易让初学者或者不熟悉的人掉入的坑。这里列举了一些python常见五大坑,以及如何避免或者解决它们。缩进问题。python使用缩进来表示代码块,...

收藏!2022年国家职业资格考试时间表公布

人社部14日公布2022年度专业技术人员职业资格考试工作计划,包括中小学生教师资格、会计师、精算师、建造师等各项考试日期。其中,证券期货基金业从业人员资格各次考试地点不同,具体安排以相关行业协会考试公...

苹果mac系统必须安装python3_macbook安装python3.7

苹果mac系统必须安装python3苹果mac系统口碑很好,但不能像linux系统一样同时提供python2和python3环境,对程序员来说是非常不友善的。资深程序员都知道,Python3才是P...

通过python实现猴子吃桃问题_python小猴子吃桃的问题

1、问题描述:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个,第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,就只剩...

python 中的第一个 hello world 程序输出

程序运行:print("helloworld")我使用的是Python程序3.7.0版本介绍下print概念print字面意思打印,将文本输出内容打印出来输入:print(&...

持久化 Python 会话:实现数据持久化和可重用性

Midjourney生成R语言会话持久化熟悉或常用R语言进行数据分析/数据挖掘/数据建模的数据工作者可能对R语言的会话保存和会话恢复印象比较深刻,它可以将当前session会话持久化保存,以便分...

如何将Python算法模型注册成Spark UDF函数实现全景模型部署

背景Background对于算法业务团队来说,将训练好的模型部署成服务的业务场景是非常常见的。通常会应用于三个场景:部署到流式程序里,比如风控需要通过流式处理来实时监控。部署到批任务中部署成API服...

Python 字典l转换成 JSON_python转化字典

本文需要5分钟。如果对您有用可以点赞评论关注.Python字典到JSONJSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式,它基于ECMAScrip...

[python] 基于PyOD库实现数据异常检测

PyOD是一个全面且易于使用的Python库,专门用于检测多变量数据中的异常点或离群点。异常点是指那些与大多数数据点显著不同的数据,它们可能表示错误、噪声或潜在的有趣现象。无论是处理小规模项目还是大型...

总结90条写Python程序的建议_python写程序的步骤

  1.首先  建议1、理解Pythonic概念—-详见Python中的《Python之禅》  建议2、编写Pythonic代码  (1)避免不规范代码,比如只用大小写区分变量、使用容易...

ptrade系列第六天:持久化处理2_持久化的三种状态

前一次跟大家分享了利用pickle进行策略数据的持久化。但是这种方式有个问题,就是保存下来的数据无法很直观的看到,比较不方便,所以今天给大家带来另一种方式,将数据通过json保存。importjso...

Python数据持久化:JSON_python的json用法

编程派微信号:codingpy上周更新的《ThinkPython2e》第14章讲述了几种数据持久化的方式,包括dbm、pickle等,但是考虑到篇幅和读者等因素,并没有将各种方式都列全。本文将介绍...

干货 | 如何利用Python处理JSON格式的数据,建议收藏

作者:俊欣来源:关于数据分析与可视化JSON数据格式在我们的日常工作中经常会接触到,无论是做爬虫开发还是一般的数据分析处理,今天,小编就来分享一下当数据接口是JSON格式时,如何进行数据处理进行详...

Python中Pyyaml模块的使用_python模块介绍

一、YAML是什么YAML是专门用来写配置文件的语言,远比JSON格式方便。YAML语言的设计目标,就是方便人类读写。YAML是一种比XML和JSON更轻的文件格式,也更简单更强大,它可以通过缩进来表...