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

python的常用库及示例

csdh11 2025-02-09 11:56 14 浏览

Python拥有丰富的库生态系统,涵盖了从数据分析到web开发的各个领域。以下是一些最常用和最重要的Python库,我会对每个库进行详细说明并提供使用示例。


1. NumPy (Numerical Python)


NumPy是Python科学计算的基础库,提供了高性能的多维数组对象和用于处理这些数组的工具。


主要特点:

- 强大的N维数组对象

- 复杂的广播功能

- 用于整合C/C++和Fortran代码的工具

- 有用的线性代数、傅里叶变换和随机数生成功能


示例:


```python

import numpy as np


# 创建数组

arr = np.array([1, 2, 3, 4, 5])


# 数学运算

print(np.mean(arr)) # 平均值

print(np.std(arr)) # 标准差


# 创建二维数组

matrix = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])


# 矩阵运算

print(np.transpose(matrix)) # 转置

print(np.linalg.inv(matrix)) # 求逆(如果可逆)


# 生成随机数

random_arr = np.random.rand(5, 5) # 5x5的随机数组


# 数组操作

reshaped = arr.reshape(5, 1) # 重塑数组形状

```


2. Pandas


Pandas是用于数据操作和分析的库。它提供了数据结构和操作工具,使处理结构化数据变得快速、灵活且富有表现力。


主要特点:

- DataFrame对象用于处理二维表格数据

- Series对象用于一维标记数组

- 处理各种文件格式(CSV、Excel、SQL数据库等)的工具

- 数据对齐和集成处理缺失数据

- 数据集的合并和连接

- 时间序列功能


示例:


```python

import pandas as pd


# 创建DataFrame

df = pd.DataFrame({

'Name': ['John', 'Anna', 'Peter', 'Linda'],

'Age': [28, 34, 29, 32],

'City': ['New York', 'Paris', 'Berlin', 'London']

})


# 基本操作

print(df.head()) # 查看前几行

print(df.describe()) # 基本统计描述


# 选择和过滤

print(df['Name']) # 选择单列

print(df[df['Age'] > 30]) # 过滤


# 添加新列

df['Country'] = ['USA', 'France', 'Germany', 'UK']


# 分组和聚合

print(df.groupby('Country')['Age'].mean())


# 读取CSV文件

# df = pd.read_csv('data.csv')


# 写入Excel文件

# df.to_excel('output.xlsx', index=False)

```


3. Matplotlib


Matplotlib是一个绘图库,用于创建静态、动画和交互式可视化。


主要特点:

- 创建高质量的图表(折线图、散点图、柱状图等)

- 可自定义的图表样式和布局

- 支持多种输出格式(PNG、PDF、SVG、动画GIF等)

- 3D图表支持


示例:


```python

import matplotlib.pyplot as plt

import numpy as np


# 创建数据

x = np.linspace(0, 2 * np.pi, 100)

y = np.sin(x)


# 创建图表

plt.figure(figsize=(10, 6))

plt.plot(x, y, label='sin(x)')

plt.title('Sine Wave')

plt.xlabel('x')

plt.ylabel('y')

plt.legend()

plt.grid(True)


# 显示图表

plt.show()


# 创建子图

fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(12, 5))


ax1.plot(x, np.sin(x), 'b-', label='sin(x)')

ax1.set_title('Sine')


ax2.plot(x, np.cos(x), 'r-', label='cos(x)')

ax2.set_title('Cosine')


for ax in (ax1, ax2):

ax.legend()

ax.grid(True)


plt.tight_layout()

plt.show()

```


4. Scikit-learn


Scikit-learn是机器学习领域最受欢迎的Python库之一,提供了各种监督和无监督学习算法。


主要特点:

- 分类、回归、聚类算法

- 模型选择和评估工具

- 数据预处理和特征选择工具

- 集成方法


示例:


```python

from sklearn import datasets, model_selection, svm, metrics

import matplotlib.pyplot as plt


# 加载数据

iris = datasets.load_iris()

X = iris.data

y = iris.target


# 分割数据集

X_train, X_test, y_train, y_test = model_selection.train_test_split(X, y, test_size=0.3, random_state=42)


# 创建和训练模型

model = svm.SVC(kernel='linear')

model.fit(X_train, y_train)


# 预测

y_pred = model.predict(X_test)


# 评估模型

print("Accuracy:", metrics.accuracy_score(y_test, y_pred))

print("\nClassification Report:\n", metrics.classification_report(y_test, y_pred))


# 可视化结果(仅使用前两个特征)

plt.figure(figsize=(10, 6))

plt.scatter(X_test[:, 0], X_test[:, 1], c=y_pred, cmap=plt.cm.Set1)

plt.title('SVM Classification Results')

plt.xlabel('Sepal length')

plt.ylabel('Sepal width')

plt.show()

```


5. TensorFlow 和 PyTorch


这两个库都是用于深度学习的强大工具。TensorFlow由Google开发,而PyTorch由Facebook开发。


主要特点:

- 构建和训练神经网络

- 自动微分功能

- GPU加速支持

- 丰富的预训练模型和工具


TensorFlow示例:


```python

import tensorflow as tf

from tensorflow.keras import layers, models


# 创建一个简单的神经网络

model = models.Sequential([

layers.Dense(64, activation='relu', input_shape=(784,)),

layers.Dense(64, activation='relu'),

layers.Dense(10, activation='softmax')

])


# 编译模型

model.compile(optimizer='adam',

loss='sparse_categorical_crossentropy',

metrics=['accuracy'])


# 假设我们有训练数据 x_train 和 y_train

# model.fit(x_train, y_train, epochs=5)


# 假设我们有测试数据 x_test

# predictions = model.predict(x_test)

```


PyTorch示例:


```python

import torch

import torch.nn as nn

import torch.optim as optim


# 定义一个简单的神经网络

class SimpleNet(nn.Module):

def __init__(self):

super(SimpleNet, self).__init__()

self.fc1 = nn.Linear(784, 64)

self.fc2 = nn.Linear(64, 64)

self.fc3 = nn.Linear(64, 10)


def forward(self, x):

x = torch.relu(self.fc1(x))

x = torch.relu(self.fc2(x))

x = self.fc3(x)

return x


# 创建模型实例

model = SimpleNet()


# 定义损失函数和优化器

criterion = nn.CrossEntropyLoss()

optimizer = optim.Adam(model.parameters())


# 训练循环(假设我们有训练数据)

# for epoch in range(5):

# for data, target in train_loader:

# optimizer.zero_grad()

# output = model(data)

# loss = criterion(output, target)

# loss.backward()

# optimizer.step()

```


6. Requests


Requests是一个简单而优雅的HTTP库,广泛用于发送HTTP/1.1请求。


主要特点:

- 简单的API设计

- 自动解码内容

- 会话和Cookie持久性

- 内置的身份验证支持


示例:


```python

import requests


# 发送GET请求

response = requests.get('https://api.github.com/user', auth=('user', 'pass'))

print(response.status_code)

print(response.headers['content-type'])

print(response.json())


# 发送POST请求

data = {'key': 'value'}

response = requests.post('https://httpbin.org/post', data=data)

print(response.text)


# 使用会话

with requests.Session() as session:

session.auth = ('user', 'pass')

response = session.get('https://api.github.com/user')

print(response.json())


# 处理异常

try:

response = requests.get('https://api.github.com/invalid', timeout=3)

response.raise_for_status()

except requests.exceptions.HTTPError as err:

print(f"HTTP error occurred: {err}")

except requests.exceptions.RequestException as err:

print(f"An error occurred: {err}")

```


7. Flask


Flask是一个轻量级的Web应用框架。它被设计为简单、灵活,并且可以快速开始开发。


主要特点:

- 内置开发服务器和调试器

- RESTful请求分发

- 模板支持(Jinja2)

- 安全的客户端会话

- 支持单元测试

- 与WSGI 1.0兼容


示例:


```python

from flask import Flask, request, jsonify


app = Flask(__name__)


@app.route('/')

def hello_world():

return 'Hello, World!'


@app.route('/user/')

def show_user_profile(username):

return f'User {username}'


@app.route('/post/')

def show_post(post_id):

return f'Post {post_id}'


@app.route('/login', methods=['GET', 'POST'])

def login():

if request.method == 'POST':

return do_the_login()

else:

return show_the_login_form()


@app.route('/api/data')

def get_data():

data = {'name': 'John', 'age': 30}

return jsonify(data)


if __name__ == '__main__':

app.run(debug=True)

```


8. Django


Django是一个高级Python Web框架,鼓励快速开发和干净、实用的设计。


主要特点:

- ORM(对象关系映射)

- URL路由

- 模板引擎

- 表单处理

- 身份验证系统

- 管理界面


示例(项目结构):


```

myproject/

manage.py

myproject/

__init__.py

settings.py

urls.py

wsgi.py

myapp/

__init__.py

admin.py

apps.py

models.py

tests.py

views.py

urls.py

```


models.py:

```python

from django.db import models


class Question(models.Model):

question_text = models.CharField(max_length=200)

pub_date = models.DateTimeField('date published')


class Choice(models.Model):

question = models.ForeignKey(Question, on_delete=models.CASCADE)

choice_text = models.CharField(max_length=200)

votes = models.IntegerField(default=0)

```


views.py:

```python

from django.http import HttpResponse

from django.shortcuts import render

from .models import Question


def index(request):

latest_question_list = Question.objects.order_by('-pub_date')[:5]

context = {'latest_question_list': latest_question_list}

return render(request, 'polls/index.html', context)


def detail(request, question_id):

question = get_object_or_404(Question, pk=question_id)

return render(request, 'polls/detail.html', {'question': question})

```


urls.py:

```python

from django.urls import path

from . import views


urlpatterns = [

path('', views.index, name='index'),

path('/', views.detail, name='detail'),

]

```


9. Selenium


Selenium是一个用于Web应用程序测试的工具。它直接驱动浏览器,模拟用户的操作。


主要特点:

- 支持多种浏览器(Chrome、Firefox、Safari等)

- 可以自动化浏览器操作

- 支持多种编程语言(Python、Java、C#等)

- 可以截图

- 支持等待和超时机制


示例:


```python

from selenium import webdriver

from selenium.webdriver.common.keys import Keys

from selenium.webdriver.common.by import By

from selenium.webdriver.support.ui import WebDriverWait

from selenium.webdriver.support import expected_conditions as EC


# 初始化驱动

driver = webdriver.Chrome() # 确保你有ChromeDriver并在PATH中


try:

# 打开网页

driver.get("http://www.python.org")


# 查找元素

search_bar = driver.find_element(By.NAME, "q")

search_bar.clear()

search_bar.send_keys("pycon")

search_bar.send_keys(Keys.RETURN)


# 等待结果加载

WebDriverWait(driver, 10).until(

EC.presence_of_element_located((By.CLASS_NAME, "list-recent-events"))

)


# 找到结果

results = driver.find_elements(By.CSS_SELECTOR, ".list-recent-events li")

for result in results:

print(result.text)


finally:

driver.quit() # 关闭浏览器

```


10. Beautiful Soup


Beautiful Soup是一个用于从HTML和XML文件中提取数据的库。它与您喜欢的解析器一起工作,提供惯用的方法来浏览、搜索和修改解析树。


主要特点:

- 简单的API

- 支持多种解析器

- 强大的搜索和导航功能

- 自动编码检测


示例:


```python

from bs4 import BeautifulSoup

import requests


# 获取网页内容

url = "http://www.python.org"

response = requests.get(url)

html_content = response.

相关推荐

探索Java项目中日志系统最佳实践:从入门到精通

探索Java项目中日志系统最佳实践:从入门到精通在现代软件开发中,日志系统如同一位默默无闻却至关重要的管家,它记录了程序运行中的各种事件,为我们排查问题、监控性能和优化系统提供了宝贵的依据。在Java...

用了这么多年的java日志框架,你真的弄懂了吗?

在项目开发过程中,有一个必不可少的环节就是记录日志,相信只要是个程序员都用过,可是咱们自问下,用了这么多年的日志框架,你确定自己真弄懂了日志框架的来龙去脉嘛?下面笔者就详细聊聊java中常用日志框架的...

物理老师教你学Java语言(中篇)(物理专业学编程)

第四章物质的基本结构——类与对象...

一文搞定!Spring Boot3 定时任务操作全攻略

各位互联网大厂的后端开发小伙伴们,在使用SpringBoot3开发项目时,你是否遇到过定时任务实现的难题呢?比如任务调度时间不准确,代码报错却找不到方向,是不是特别头疼?如今,随着互联网业务规模...

你还不懂java的日志系统吗 ?(java的日志类)

一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...

谈谈枚举的新用法--java(java枚举的作用与好处)

问题的由来前段时间改游戏buff功能,干了一件愚蠢的事情,那就是把枚举和运算集合在一起,然后运行一段时间后buff就出现各种问题,我当时懵逼了!事情是这样的,做过游戏的都知道,buff,需要分类型,且...

你还不懂java的日志系统吗(javaw 日志)

一、背景在java的开发中,使用最多也绕不过去的一个话题就是日志,在程序中除了业务代码外,使用最多的就是打印日志。经常听到的这样一句话就是“打个日志调试下”,没错在日常的开发、调试过程中打印日志是常干...

Java 8之后的那些新特性(三):Java System Logger

去年12月份log4j日志框架的一个漏洞,给Java整个行业造成了非常大的影响。这个事情也顺带把log4j这个日志框架推到了争议的最前线。在Java领域,log4j可能相对比较流行。而在log4j之外...

Java开发中的日志管理:让程序“开口说话”

Java开发中的日志管理:让程序“开口说话”日志是程序员的朋友,也是程序的“嘴巴”。它能让程序在运行过程中“开口说话”,告诉我们它的状态、行为以及遇到的问题。在Java开发中,良好的日志管理不仅能帮助...

吊打面试官(十二)--Java语言中ArrayList类一文全掌握

导读...

OS X 效率启动器 Alfred 详解与使用技巧

问:为什么要在Mac上使用效率启动器类应用?答:在非特殊专业用户的环境下,(每天)用户一般可以在系统中进行上百次操作,可以是点击,也可以是拖拽,但这些只是过程,而我们的真正目的是想获得结果,也就是...

Java中 高级的异常处理(java中异常处理的两种方式)

介绍异常处理是软件开发的一个关键方面,尤其是在Java中,这种语言以其稳健性和平台独立性而闻名。正确的异常处理不仅可以防止应用程序崩溃,还有助于调试并向用户提供有意义的反馈。...

【性能调优】全方位教你定位慢SQL,方法介绍下!

1.使用数据库自带工具...

全面了解mysql锁机制(InnoDB)与问题排查

MySQL/InnoDB的加锁,一直是一个常见的话题。例如,数据库如果有高并发请求,如何保证数据完整性?产生死锁问题如何排查并解决?下面是不同锁等级的区别表级锁:开销小,加锁快;不会出现死锁;锁定粒度...

看懂这篇文章,你就懂了数据库死锁产生的场景和解决方法

一、什么是死锁加锁(Locking)是数据库在并发访问时保证数据一致性和完整性的主要机制。任何事务都需要获得相应对象上的锁才能访问数据,读取数据的事务通常只需要获得读锁(共享锁),修改数据的事务需要获...