python 實現(xiàn)分組求和與分組累加求和代碼
我就廢話不多說了,大家還是直接看代碼吧!
# -*- encoding=utf-8 -*-
import pandas as pd
data=['abc','abc','abc','asc','ase','ase','ase']
num=[1,2,2,1,2,1,2]
df1=pd.DataFrame({'name':data,'num':num})
print(df1)
df1['mmm']=df1['num']
df2=df1.groupby(['name', 'num'], as_index=False).count()
print(df2)
df2.sort_values(['name', 'num'], ascending=[1, 1], inplace=True)
print(df2)
df2['sum']=df2.groupby(['name'])['mmm'].cumsum()
print(df2)
kk=df2.groupby(['name'],as_index=False)['num'].sum()
print(kk)
df3 = pd.merge(df2, kk, on='name', how='left',)
print(df3)
df3['ratio']=df3['sum']/df3['num_y']
df3.columns = ['name', 'num', 'mmm', 'sum','numsum','ratio']
print(df3)
df4=df3.groupby(['mmm'],as_index=False)['ratio'].mean()
print(df4)
運行:
name num 0 abc 1 1 abc 2 2 abc 2 3 asc 1 4 ase 2 5 ase 1 6 ase 2 name num mmm 0 abc 1 1 1 abc 2 2 2 asc 1 1 3 ase 1 1 4 ase 2 2 name num mmm 0 abc 1 1 1 abc 2 2 2 asc 1 1 3 ase 1 1 4 ase 2 2 name num mmm sum 0 abc 1 1 1 1 abc 2 2 3 2 asc 1 1 1 3 ase 1 1 1 4 ase 2 2 3 name num 0 abc 3 1 asc 1 2 ase 3 name num_x mmm sum num_y 0 abc 1 1 1 3 1 abc 2 2 3 3 2 asc 1 1 1 1 3 ase 1 1 1 3 4 ase 2 2 3 3 name num mmm sum numsum ratio 0 abc 1 1 1 3 0.333333 1 abc 2 2 3 3 1.000000 2 asc 1 1 1 1 1.000000 3 ase 1 1 1 3 0.333333 4 ase 2 2 3 3 1.000000 mmm ratio 0 1 0.555556 1 2 1.000000 Process finished with exit code 0
補充知識:python項目篇-對符合條件的某個字段進行求和,聚合函數(shù)annotate(),aggregate()函數(shù)
對符合條件的某個字段求和
需求是,計算每日的收入和
1、
new_dayincome = request.POST.get("dayincome_time", None)
# total_income = models.bathAccount.objects.filter(dayBath=new_dayincome).aggregate(nums=Sum('priceBath'))
total_income = models.bathAccount.objects.values('priceBath').annotate(nums=Sum('priceBath')).filter(dayBath=new_dayincome)
print("total_income",total_income[0]['nums'])
輸出結(jié)果:total_income 132
2、
from django.db.models import Sum,Count
new_dayincome = request.POST.get("dayincome_time", None)
total_income = models.bathAccount.objects.filter(dayBath=new_dayincome).aggregate(nums=Sum('priceBath'))
print("total_income",total_income['nums'])
輸出結(jié)果:total_income 572
第二種輸出的是正確的數(shù)字
以上這篇python 實現(xiàn)分組求和與分組累加求和代碼就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
如何將Pycharm中調(diào)整字體大小的方式設(shè)置為"ctrl+鼠標滾輪上下滑"
這篇文章主要介紹了如何將Pycharm中調(diào)整字體大小的方式設(shè)置為"ctrl+鼠標滾輪上下滑",本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11
Python中xml和dict格式轉(zhuǎn)換的示例代碼
最近在做APP的接口,遇到XML格式的請求數(shù)據(jù),費了很大勁來解決,下面小編給大家分享下Python中xml和dict格式轉(zhuǎn)換問題,感興趣的朋友跟隨小編一起看看吧2019-11-11
Python解析excel文件存入sqlite數(shù)據(jù)庫的方法
最近工作中遇到一個需求,需要使用Python解析excel文件并存入sqlite,本文就實現(xiàn)的過程做個總結(jié)分享給大家,文中包括數(shù)據(jù)庫設(shè)計、建立數(shù)據(jù)庫、Python解析excel文件、Python讀取文件名并解析和將解析的數(shù)據(jù)存儲入庫,有需要的朋友們下面來一起學(xué)習學(xué)習吧。2016-11-11
Python實現(xiàn)PDF與多種圖片格式之間互轉(zhuǎn)(PNG, JPG, BMP, EMF,&nb
PDF和圖片是我們?nèi)粘I詈凸ぷ髦谐S玫奈募袷?有時候,我們可能需要將PDF和圖片進行格式互轉(zhuǎn)來滿足不同的應(yīng)用場景和使用需求,這篇文章將探討如何使用Python實現(xiàn)PDF與多種圖片格式之間的相互轉(zhuǎn)換,需要的朋友可以參考下2025-03-03
python3.7環(huán)境下sanic-ext未生效踩坑解析
這篇文章主要為大家介紹了python3.7環(huán)境下sanic-ext未生效踩坑解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01

