Python数据分析(Series+DataFrame+部分运算+groupby)

Pandas操作财报数据

Series

type() 返回变量类型
可见ser_obj类型为<class 'pandas.core.series.Series'>

python 复制代码
import pandas as pd

ser_obj = pd.Series([9,2,'a',4,5],index=['11','22','33','44','aa'])
data={'Tome':'aa','Marry':'bb'}
print(type(ser_obj))
print(ser_obj)

ser_obj2=pd.Series(data)
print(ser_obj2)
print(ser_obj.index,ser_obj.values)

DataFrame


df类型为<class 'pandas.core.frame.DataFrame'>

python 复制代码
data=[[1,2,3],['a','b','c'],['!','@','$']]
df1=pd.DataFrame(data,columns=['A','B','C'],index=['1','2','3'])#添加列索引,行索引

print(type(df1))
print(df1)

读文件内容

python 复制代码
CSoft = pd.read_excel('E:\AAA工作\授课\大数据技术应用基础\代码文件和素材文件\ch6\data.xlsx',sheet_name='CSoft',usecols='A,B',nrows=2)# 只导入AB列,前两行
print(CSoft)


CSoft.to_excel('data1.xlsx')

import numpy as np 
df2=pd.DataFrame(np.random.rand(8,4),columns=['A','B','C','D'])
df2

读取

ser[0] 位置索引

ser['name']标签索引

ser[0:4] 【0,4)位置切片

ser['a':'d'] 【'a','d'】标签切片

ser[['a','d','f']] 用列表盛放多个

df[列索引][行索引]

df.loc(x,y) 标签 【x,y】 闭区间

df.iloc(x,y) 位置 【x,y)左闭右开区间

python 复制代码
print(df2.loc[1:2,'A'])
print(type(df2.loc[1:2,'A']))

排序

python 复制代码
df2.sort_index(axis=1,ascending=False) # axis=1列标签 axis=0行标签

df2.sort_values(by='A',ascending=False,axis=0) # axis=1列标签 axis=0行标签

计算

python 复制代码
df2['A'].quantile(q=0.5)#偶数就按中间两个数的均值

df3=pd.read_excel('E:\AAA工作\授课\大数据技术应用基础\代码文件和素材文件\ch7\MG公司2023年销售数据.xlsx')
df3
python 复制代码
df3['利润']=df3['销售金额']-df3['成本']

df3['销售金额'].describe()

df3['产品名称'].count()

groupby

python 复制代码
a1=df3['销售金额'].groupby(df3['地域'])
a2=df3.groupby('地域')
print(type(a1))# groupby.generic.SeriesGroupBy
print(type(a2))# groupby.generic.DataFrameGroupBy
print(a1)# 是多个元组所以得用循环查看。每个元组第一个元素是分组的字段值第二个元素是数据表
for i in a1:# 每个元组查看
    print(type(i[0]),type(i[1]))# str,pandas.core.series.Series也就是Series对象
    print(i[0])
    print(i[1])
    break
python 复制代码
a2=df3.groupby('地域')
print(type(a2))# groupby.generic.DataFrameGroupBy
for i in a2:# 每个元组查看
    print(type(i[0]),type(i[1]))# str,pandas.core.frame.DataFrame也就是DataFrame对象
    print(i[0])
    print(i[1])
    break

对分组后的组对象可以对其值求和,这里就是按地域分组后的销售金额求和

python 复制代码
print(type(df3['销售金额'].groupby(df3['地域']).sum()))
print(df3['销售金额'].groupby(df3['地域']).sum())# 求和使得数据类型变为pandas.core.series.Series

以上代码由于df3.groupby('地域')得到的组对象中还是个矩阵DataFrame,所以.sum()就将所有列分别求和了

python 复制代码
print(type(df3.groupby('地域').sum()))# frame.DataFrame
print(type(df3.groupby('地域')['销售金额'].sum()))# series.Series
print(df3.groupby('地域').sum())#

一般还是先分组再取列更常用

python 复制代码
a2=df3.groupby(['地域','日期'])
a2.sum()
相关推荐
宇木灵1 小时前
C语言基础-八、结构体和共同(用)体
c语言·开发语言·数据结构·笔记·学习·算法
拳里剑气2 小时前
C++ 11
开发语言·c++·学习方法
孞㐑¥2 小时前
算法—穷举,爆搜,深搜,回溯,剪枝
开发语言·c++·经验分享·笔记·算法
2401_828890642 小时前
通用唤醒词识别模型 - Wav2Vec2
人工智能·python·深度学习·audiolm
nita张2 小时前
2026年2月实战案例分享:合肥战略定位成果解析
人工智能·python
桂花很香,旭很美2 小时前
大模型项目实战:Python 异步——提速、流式、多 Agent
python·language model
yaoxin5211232 小时前
330. Java Stream API - 处理 Optional 对象:像流一样优雅地使用 Optional
java·windows·python
aningxiaoxixi2 小时前
Android Audio 广播之 ACTION_AUDIO_BECOMING_NOISY
android·java·python
Highcharts.js2 小时前
如何根据派生数据创建钟形曲线图表?highcharts正态分布曲线使用指南:从创建到设置一文搞定
开发语言·javascript·开发文档·正态分布·highcharts·图表类型·钟形图