python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > python统计分析处理函数

python常见统计分析处理函数解读

作者:DB_UP

这篇文章主要介绍了python常见统计分析处理函数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一、分组统计

1、分组后对不同指标统计分析

df=data.groupby(['city','date']).agg({'tem':np.mean, "tem_max":np.max, "tem_min":np.min})
la=launch.groupby(['user_id','launch_day'],as_index=False).agg({'launch':'sum'})#as_index得到的表格就没有使用group_id作为索引
_funcs = ['mean', 'std', 'sum']
##遍历每一种统计指标
for _func in _funcs:
    # 对每一个样本计算各项指标
    df[f'P2_C2-C5_{_func}'] = raw[['A10', 'A12', 'A15', 'A17']].agg(_func, axis=1)

2、数据框中多列同时乘以同一列值计算

def calculate_profit(load_price):
    """计算利润"""
    # 定义利润计算函数
    # 计算各个季节的利润
    for season in ['春季', '夏季', '秋季', '冬季']:
        column_name = f'{season}充放电负荷'
        profit_column_name = f'{season}利润'
        load_price[profit_column_name] = load_price.apply(lambda row: row[column_name] * row['电价'], axis=1)
    return load_price

二、重要函数(apply、map、filter、query、replace、reduce)

1、对数据框下的列进行统计分析:apply+lambda函数

Weekday_Spring_Autumn['weekday_mean']=Weekday_Spring_Autumn.apply(lambda x: x.mean(),axis=1)

2、数据类型转换(float—int):map()函数

map 函数,它接收两个参数,第一个参数是一个函数对象 (当然也可以是一个lambda表达式),第二个参数是一个序列。

map(lambda x: x*2,[1,2,3,4,5])
#输出:[2,4,6,8,10]
#可以很清楚地看到,它可以将后面序列中的每一个元素做为参数传入lambda中。
normal.iloc[:,0]=normal.iloc[:,0].map(int)
df['time_interval_begin'] = pd.to_datetime(df['time_interval'].map(lambda x: x[1:20]))
df_trn['A25'] = df_trn['A25'].replace('1900/3/10 0:00', 70).astype(int)

2.1、删除数据间空格 map+strip

使用strip函数:#删除左右两边空格
df2['Chinese']=df2['Chinese'].map(str.strip)
#删除左边空格
df2['Chinese']=df2['Chinese'].map(str.lstrip)
#删除右边空格
df2['Chinese']=df2['Chinese'].map(str.rstrip)
有某个特殊的符号,$,我们想把这个删掉
df2['Chinese']=df2['Chinese'].str.strip($S)
result_owner.card=result_owner.card.map(lambda x:x.lower()) #身份证字母大写改小写
result_card=result_owner[result_owner['card'].str.len()==18] #删除身份证不是18位,匹配位18位
result_card_new['年龄']=[(2021-int(float(x[6:10]))) for x in result_card_new['card']] #年龄

3、数据筛选filter()函数

flter 函数,和map 函数相似。同样也是接收两个参数,一个lambda 表达式,一个序列。

它会遍历后面序列中每一个元素,并将其做为参数传入lambda表达式中,当表达式返回 True,则元素会被保留下来,当表达式返回 False,则元素会被丢弃。

cols_timer = list(filter(lambda x: x.endswith('t'), df_trn_tst.columns))

4、np.where和query

np.where(condition, x, y) #满足条件(condition),输出x,不满足输出y,只有条件 (condition),没有x和y,则输出满足条件 (即非0) 元素的坐标
duration = np.where(duration < 0, duration + 24*60, duration)
df_trn.query('收率 > 0.8671')

5、replace替换(两种:对每个记录修改,记录中数据修改)

'''G3i修改为G3'''
result_dfa['vehicles']=[result_dfa['vehicles'].iloc[i].replace('G3i','小鹏G3') for i in range(len(result_dfa))]
result_dfa['brand']=result_dfa['brand'].replace(['天津一汽丰田','四川一汽丰田(长春丰越)'],'一汽丰田')

6、reduce函数

reduce 函数,也是类似的。它的作用是先对序列中的第 1、2 个元素进行操作,得到的结果再与第三个数据用 lambda 函数运算,将其得到的结果再与第四个元素进行运算,以此类推下去直到后面没有元素了。

reduce(lambda x,y:x+y,[1,2,3,4])
#输出:15

三、行/列相关操作

1、删除列/行操作

year_elect_data=year_elect_data.drop(['ind','年'],axis=1) #删除两列,axis=0行操作
del df_trn['收率']

industry_data_new.drop(industry_data_new.columns[1:3], axis=1, inplace=True) #删除某几列数据

df2=df2.drop(columns=['Chinese']) #我们想把“语文”这列删掉
df2=df2.drop(index=["ZhangFei'']) #想把“张飞”这行删掉。

result_vin=result_df.drop_duplicates(subset='vin',keep='first')  #删除vin重复数据,保留第一个出现的

'''删除EC60'''
result_dfa=result_dfa[~result_dfa['vehicles'].isin(['EC60'])]
result_dfa

2、 查找某列特征数据(字符型)

obj_columns=df.select_dtypes(['object'])
col=obj_columns.columns
df.drop(columns=col,inplace=True) #删除字符串数据

筛选某列数据不为空的数据集:notnull()

ind=df[df.data.notnull()]  
ind=df[df['data'].notnull()]

'''删除EC60'''
result_dfa=result_dfa[~result_dfa['vehicles'].isin(['EC60'])]
result_dfa

3、列重命名

Year_Elect=Year_elect.rename(columns={"index":"指标名称"})
Year_elect=Year_elect.rename(columns={_col: _col + '_t' for _col in cols_timer},inplace=True)
# 批量更改列名
df.rename(columns=lambda x: x + '_1')

4、包含某个特殊字符的列:contains()

Industry_Data.columns.str.contains('_x')
#提取含有字符串'hello'的行
#方法一:
df[df['ass']=='hello']
#方法二:
re=df['ass'].str.contains('hello')
df[re]

5、筛选需要的行业数据:存在isin()/不存在

ind_data=ind[ind.行业名称.isin(industry_division.指标名称)] #industry_division.指标名称--industry_division对应指标名称列下的行业
Spring_Autumn_weekend=Spring_Autumn_weekend[~Spring_Autumn_weekend.isin(Statutory_holidays)]  #删除法定节假日
#取出满足条件的数据
result_vin_mobile=result_vin[result_vin['mobile'].str.len()==11]#手机号长度为11位 

6、根据某几列数据排序sort_values()

dff=One_Weather_data.sort_values(['最高温度','行业'],inplace=True)

7、统计gram列每种语言出现的次数

df['gram'].value_counts()

8、将空值用上下值的平均值进行填充

df['score']=df['score'].fillna(df['score'].interpolate())

9、交换两列的位置

#方式一:
temp=df['gram']
df.drop(labels=['gram'],axis=1,inplace=True)
df.insert(0,'gram',temp)
#方式二:
cols=df.columns[[1,0]]
df=df[cols]

10、新增一列根据salary将数据分为三组

bins=[0,5000,20000,50000]
group_name=['低','中','高']
df['categrories']=pd.cut(df['salary'],bins,labels=group_name)

11、将两列合成一列

df['test']=df['edf']+df['crt']  #两列都是字符型
df['test1']=df['salary'].map(str)+df['crt'] #salary 为int类型

12、拆分某列,生成新的Dataframe

df1 = df['行业'].str.split('-',expand=True)
df1.columns = ['编号','行业']

13、多列减去一列

Spring_Air=Spring_Air_Elec-Spring_Air_Reference_Elec.values[:, None] #

四、数据框

1、对数据框按照分组进行标准化

df['data_standardized'] = df.groupby('group')['data'].transform(lambda x: (x - np.mean(x)) / np.std(x))
##对数据框按照分组,取该组最后一个值
df['data_last'] = df.groupby('group')['data'].transform('last')
#对数据框按照分组,对空值进行平均值填充
df['data_filled'] = df.groupby('group')['data'].transform(lambda x: x.fillna(x.mean()))

2、数据透视表

#单索引
df_pivot = pd.pivot_table(df,values ='商业销量', index = ['年月'], aggfunc=np.sum, fill_value=0) #当我们未设置aggfunc时,它默认aggfunc='mean'计算均值。fill_value,用0填充空值
#多索引
df_pivot = pd.pivot_table(df,values ='商业销量', index = ['品牌','经销商','年月'], columns=['系列'],aggfunc=np.sum, fill_value=0)#aggfunc可以多参数,如aggfunc=[np.mean,len,np.sum]),aggfunc={'数量':len,'价格':np.sum}
#数据透视表过滤
df_pivot = pd.pivot_table(df,values ='商业销量', index = ['品牌','经销商', '年月'], columns=['系列'],aggfunc=np.sum, fill_value=0)
df=df_pivot.reset_index()  #重置索引

df_pivot.query("品牌==['奔驰','宝马']")
#get_level_values来获得不同级别索引
df_pivot.index.get_level_values(0).unique()  #各品牌数据
df_pivot.index.get_level_values(1).unique()  #各经销商数据
df_pivot.xs(('奔驰','宝马'),level=0)  #数据转存excel

3、统计指标0和空值数据

null_per=100*(df.isnull()).sum(axis=0)/len(df)
zero_per=100*(df==0).sum(axis=0)/len(df)
new=null_per+zero_per

4、检查数据中是否含有任何缺失值

df.isnull().values.any()

5、数据向前/后移动5天

data.shift(-5)
data.shift(5)

6、按周采样,取一周最大值

data['收盘价'].resample('W').max()

7、计算前一天与后一天变化率

data['收盘价'].pct_change()

8、将小数转化为百分数

df.style.format({'data':'{0:.2%}'.format})

9、列表生成式:新增数据列

Season_Weekday['Time_label']=[str(i) +'_'+ 'weekday' for i in pd.to_datetime(Season_Weekday.index).month]
#从一个列表中
[ i for i in range(9) if i %2 == 0]
#从两个列表中进行推导
[(i,j) for i in range(5) for j in range(5)]

10、新建excel写入数据

write=pd.ExcelWriter(r'各行业重点企业清单\\%s.xlsx'%(hy[0]))
jl.to_excel(write,sheet_name='xx')
write.save()

五、时间数据

1、时间范围区间选择:date_range

from pandas import date_range
Start=pd.to_datetime('%s-04-15'%Year)
End=pd.to_datetime('%s-05-15'%Year)
Tyday=pd.date_range(start=Start,end=End)

2、将time列时间转换为月-日(月、年月日)

for i in range(len(df)):
	df.iloc[i,0]=df.iloc[i,0].to_pydatetime().strftime("%m-%d")
Weather['Year_Month']=Weather['Date'].map(lambda x: x.to_pydatetime().strftime("%Y-%m"))
Industry_Factor_Data["Date"]=pd.to_datetime(Industry_Factor_Data["Date"], format='%Y%m')
df['order_date'] = pd.to_datetime(df.order_dt,format="%Y%m%d")
df['month'] = df.order_date.values.astype('datetime64[M]')

忽略警告

import warnings
warnings.filterwarnings("ignore")

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文