Python 数据分析与可视化 Day 1 - Pandas 数据分析基础入门

🎯 今日目标

  • 理解 Pandas 的作用和核心概念
  • 学会创建 Series 和 DataFrame
  • 掌握基本数据读取(CSV)与常用查看方法

🧰 1. 什么是 Pandas?

Pandas 是基于 NumPy 的强大数据分析库,提供了灵活的表格数据结构 DataFrame,让你可以像操作 Excel 或数据库一样处理数据。


🧱 2. 核心数据结构

🧩 Series(带标签的一维数组)

python 复制代码
import pandas as pd

s = pd.Series([90, 85, 78], index=["张三", "李四", "王五"])
print(s)

输出:

python 复制代码
张三    90
李四    85
王五    78
dtype: int64

🧩 DataFrame(二维表格)

python 复制代码
data = {
    "姓名": ["张三", "李四", "王五"],
    "成绩": [90, 85, 78],
    "是否及格": [True, True, False]
}

df = pd.DataFrame(data)
print(df)

输出:

python 复制代码
   姓名  成绩  是否及格
0  张三   90   True
1  李四   85   True
2  王五   78  False

📖 3. 数据导入(CSV 文件)

python 复制代码
df = pd.read_csv("students.csv", encoding="utf-8")
print(df.head())   # 查看前几行
print(df.info())   # 概况
print(df.describe())  # 描述性统计(数值字段)

🔧 4. 常用基本操作

python 复制代码
print(df["成绩"])               # 访问某列
print(df.iloc[0])               # 按行索引访问
print(df[df["成绩"] >= 80])    # 筛选数据
print(df.sort_values("成绩", ascending=False))  # 排序

🧪 今日练习任务

  1. 创建一个 DataFrame,包含 5 名学生的姓名、性别、成绩、是否及格字段

    python 复制代码
    data = {
        "姓名": ["张三", "李四", "王五", "赵六", "钱七"],
        "成绩": [90, 85, 78, 88, 92],
        "是否及格": [True, True, False, True, True],
        "性别": ["男", "女", "男", "女", "男"]
    }
    
    df = pd.DataFrame(data)
    print(df)

    输出:

    python 复制代码
       姓名  成绩   是否及格 性别
    0  张三  90   True  男
    1  李四  85   True  女
    2  王五  78  False  男
    3  赵六  88   True  女
    4  钱七  92   True  男
  2. 筛选出所有不及格学生并打印

    python 复制代码
    failing_students = df[df["是否及格"] == False]
    print("不及格学生:")
    print(failing_students)

    输出:

    python 复制代码
    不及格学生:
       姓名  成绩   是否及格 性别
    2  王五  78  False  男
  3. 计算成绩的平均分、最大分、最小分

    python 复制代码
    average_score = df["成绩"].mean()
    max_score = df["成绩"].max()
    min_score = df["成绩"].min()

    输出:

    python 复制代码
    平均分: 86.6, 最大分: 92, 最小分: 78
  4. 将该 DataFrame 保存为 students.csv 文件(使用 to_csv

    python 复制代码
    df.to_csv("students.csv", index=False, encoding='utf-8-sig')
    print("DataFrame 已保存为 students.csv 文件")

    输出:

    python 复制代码
    DataFrame 已保存为 students.csv 文件

✅ 示例:保存为 CSV 文件

python 复制代码
df.to_csv("students.csv", index=False, encoding="utf-8")

✍️ 今日总结

  • 掌握了 Pandas 的核心结构:Series 与 DataFrame
  • 学会了基本的数据读取、创建和查看方法
  • 初步能用 Pandas 做简单的数据筛选、排序和保存

题外话

相关推荐
橙 子_3 小时前
基于 Amazon Nova Sonic 和 MCP 构建语音交互 Agent
python
宇寒风暖5 小时前
Flask 框架全面详解
笔记·后端·python·学习·flask·知识
哪 吒5 小时前
【2025C卷】华为OD机试九日集训第3期 - 按算法分类,由易到难,提升编程能力和解题技巧
python·算法·华为od·华为od机试·2025c卷
charlee446 小时前
PandasAI连接LLM对MySQL数据库进行数据分析
mysql·数据分析·nlp·pandasai·deepseek
rockmelodies6 小时前
RSA 解密逻辑
开发语言·python
Tobiichiorigami.7 小时前
Python训练Day30
python
Hygge-star8 小时前
【Excel】利用函数和Power Query进行数据分析
数据挖掘·数据分析·excel
Dxy12393102168 小时前
python创建一个excel文件
开发语言·python·excel
lingling0099 小时前
生物医药研究数据分析工具测评:衍因科技如何重塑科研范式?
科技·数据挖掘·数据分析
涡能增压发动积10 小时前
Browser-Use Agent使用初体验
人工智能·后端·python