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()
相关推荐
kkeeper~5 小时前
0基础C语言积跬步之深入理解指针(5下)
c语言·开发语言
一直不明飞行5 小时前
Java的equals(),hashCode()应该在什么时候重写
java·开发语言·jvm
2301_803934615 小时前
Go语言如何做网络爬虫_Go语言爬虫开发教程【指南】
jvm·数据库·python
WL_Aurora5 小时前
Python爬虫实战(六):新发地蔬菜价格数据采集.
爬虫·python
盲敲代码的阿豪6 小时前
Python 入门基础教程(爬虫前置版)
开发语言·爬虫·python
basketball6166 小时前
C++ 构造函数完全指南:从入门到进阶
java·开发语言·c++
互联科技报6 小时前
2026超融合选型:Top5品牌与市场格局解读
开发语言·perl
weixin199701080166 小时前
[特殊字符] 智能数据采集:数字化转型的“数据石油勘探队”(附Python实战源码)
开发语言·python
想唱rap7 小时前
IO多路转接之poll
服务器·开发语言·数据库·c++
@杰克成7 小时前
Java学习30
java·开发语言·学习