名称: Excel分析 描述: 分析Excel电子表格,创建透视表,生成图表,并进行数据分析。适用于分析Excel文件、电子表格、表格数据或.xlsx文件。
Excel分析
快速开始
使用pandas读取Excel文件:
import pandas as pd
# 读取Excel文件
df = pd.read_excel("data.xlsx", sheet_name="Sheet1")
# 显示前几行
print(df.head())
# 基本统计信息
print(df.describe())
读取多个工作表
处理工作簿中的所有工作表:
import pandas as pd
# 读取所有工作表
excel_file = pd.ExcelFile("workbook.xlsx")
for sheet_name in excel_file.sheet_names:
df = pd.read_excel(excel_file, sheet_name=sheet_name)
print(f"
{sheet_name}:")
print(df.head())
数据分析
执行常见分析任务:
import pandas as pd
df = pd.read_excel("sales.xlsx")
# 分组和聚合
sales_by_region = df.groupby("region")["sales"].sum()
print(sales_by_region)
# 过滤数据
high_sales = df[df["sales"] > 10000]
# 计算指标
df["profit_margin"] = (df["revenue"] - df["cost"]) / df["revenue"]
# 按列排序
df_sorted = df.sort_values("sales", ascending=False)
创建Excel文件
将数据写入Excel并添加格式:
import pandas as pd
df = pd.DataFrame({
"产品": ["A", "B", "C"],
"销售额": [100, 200, 150],
"利润": [20, 40, 30]
})
# 写入Excel
writer = pd.ExcelWriter("output.xlsx", engine="openpyxl")
df.to_excel(writer, sheet_name="销售额", index=False)
# 获取工作表以进行格式设置
worksheet = writer.sheets["销售额"]
# 自动调整列宽
for column in worksheet.columns:
max_length = 0
column_letter = column[0].column_letter
for cell in column:
if len(str(cell.value)) > max_length:
max_length = len(str(cell.value))
worksheet.column_dimensions[column_letter].width = max_length + 2
writer.close()
透视表
以编程方式创建透视表:
import pandas as pd
df = pd.read_excel("sales_data.xlsx")
# 创建透视表
pivot = pd.pivot_table(
df,
values="sales",
index="region",
columns="product",
aggfunc="sum",
fill_value=0
)
print(pivot)
# 保存透视表
pivot.to_excel("pivot_report.xlsx")
图表和可视化
从Excel数据生成图表:
import pandas as pd
import matplotlib.pyplot as plt
df = pd.read_excel("data.xlsx")
# 创建条形图
df.plot(x="category", y="value", kind="bar")
plt.title("按类别销售额")
plt.xlabel("类别")
plt.ylabel("销售额")
plt.tight_layout()
plt.savefig("chart.png")
# 创建饼图
df.set_index("category")["value"].plot(kind="pie", autopct="%1.1f%%")
plt.title("市场份额")
plt.ylabel("")
plt.savefig("pie_chart.png")
数据清洗
清理和准备Excel数据:
import pandas as pd
df = pd.read_excel("messy_data.xlsx")
# 移除重复项
df = df.drop_duplicates()
# 处理缺失值
df = df.fillna(0) # 或使用 df.dropna()
# 移除空白字符
df["name"] = df["name"].str.strip()
# 转换数据类型
df["date"] = pd.to_datetime(df["date"])
df["amount"] = pd.to_numeric(df["amount"], errors="coerce")
# 保存清理后的数据
df.to_excel("cleaned_data.xlsx", index=False)
合并和连接
组合多个Excel文件:
import pandas as pd
# 读取多个文件
df1 = pd.read_excel("sales_q1.xlsx")
df2 = pd.read_excel("sales_q2.xlsx")
# 垂直拼接
combined = pd.concat([df1, df2], ignore_index=True)
# 基于公共列合并
customers = pd.read_excel("customers.xlsx")
sales = pd.read_excel("sales.xlsx")
merged = pd.merge(sales, customers, on="customer_id", how="left")
merged.to_excel("merged_data.xlsx", index=False)
高级格式设置
应用条件格式和样式:
import pandas as pd
from openpyxl import load_workbook
from openpyxl.styles import PatternFill, Font
# 创建Excel文件
df = pd.DataFrame({
"产品": ["A", "B", "C"],
"销售额": [100, 200, 150]
})
df.to_excel("formatted.xlsx", index=False)
# 加载工作簿以进行格式设置
wb = load_workbook("formatted.xlsx")
ws = wb.active
# 应用条件格式
red_fill = PatternFill(start_color="FF0000", end_color="FF0000", fill_type="solid")
green_fill = PatternFill(start_color="00FF00", end_color="00FF00", fill_type="solid")
for row in range(2, len(df) + 2):
cell = ws[f"B{row}"]
if cell.value < 150:
cell.fill = red_fill
else:
cell.fill = green_fill
# 加粗表头
for cell in ws[1]:
cell.font = Font(bold=True)
wb.save("formatted.xlsx")
性能提示
- 使用
read_excel配合usecols仅读取特定列 - 使用
chunksize处理非常大的文件 - 根据文件类型考虑使用
engine='openpyxl'或engine='xlrd' - 使用
dtype参数指定列类型以加速读取
可用包
- pandas - 数据分析和操作(主要)
- openpyxl - Excel文件创建和格式设置
- xlrd - 读取旧的.xls文件
- xlsxwriter - 高级Excel写入功能
- matplotlib - 图表生成