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 做简单的数据筛选、排序和保存

题外话

相关推荐
vx-程序开发6 小时前
springboot在线装修管理系统-计算机毕业设计源码56278
java·c语言·spring boot·python·spring·django·php
进击的雷神6 小时前
主办方过滤、展位号模糊提取、多层级官网爬取、缅文编码解码——缅甸塑料展爬虫四大技术难关攻克纪实
网络·爬虫·python
winfredzhang6 小时前
用 Python + DeepSeek AI 构建文件批量重命名与智能管理工具
python·api·重命名·预览·解压·deepseek
西西弗Sisyphus6 小时前
Python 中__pycache__文件夹
python
qingcyb7 小时前
重复 id 对应的多个对象
开发语言·python
mingshili7 小时前
[python] asyncio常规操作记录
python·async
chushiyunen7 小时前
python edge-tts实现tts文本转语音、音频
数据库·python·音视频
嫂子的姐夫7 小时前
040-spiderbuf第C8题
javascript·爬虫·python·js逆向·逆向
江上清风山间明月7 小时前
python将dtso文件转换成dtbo文件
python·dts·dtso
天下无贼!7 小时前
【Python】2026版——FastAPI 框架快速搭建后端服务
开发语言·前端·后端·python·aigc·fastapi