电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Python 對Excel求和、合并居中的操作

瀏覽:3日期:2022-06-24 16:51:41
需求

原始表格:

Python 對Excel求和、合并居中的操作

想在Total列中對每日的Amount進行匯總,然后對Date和Total進行合并居中,效果如下:

Python 對Excel求和、合并居中的操作

思路

遍歷Excel行,從第一個非空Date列開始,到下個非空Date列,對Amount列進行求和,結果賦給第一個非空Data列對應行的Total列。

代碼

import osimport openpyxlfrom openpyxl.styles import Border, Side, PatternFill, Font, GradientFill, Alignmentdef range_sum(worksheet,start,end): sum = 0 for row in worksheet[start:end]: for cell in row: if cell.value != None:sum += cell.value return sumdef is_blank_row(worksheet,row_num,max_col=None): if not max_col: max_col = worksheet.max_column for cell in worksheet[row_num][:max_col]: if cell.value: return False return Truedef total_amount(worksheet): ''' 對某sheet的A、E列合并居中,并對E列求和 ''' ws = worksheet row, max_row = 4, ws.max_row while row < ws.max_row: sum_row_start, sum_row_end = row, row for working_row in range(row + 1,max_row + 2): if (not is_blank_row(worksheet, working_row-1) # 上一行有值 and (ws[f’A{working_row}’].value or is_blank_row(worksheet, working_row))): # A列有值 或 當前為空行(最后一次合并) # 求和 sum_row_end = working_row - 1 ws[f’E{sum_row_start}’] = range_sum(ws,f’C{sum_row_start}’,f’C{sum_row_end}’) # 合并居中 ws[f’E{sum_row_start}’].alignment = Alignment(horizontal='center', vertical='center') ws[f’A{sum_row_start}’].alignment = Alignment(horizontal='center', vertical='center') ws.merge_cells(f’E{sum_row_start}:E{sum_row_end}’) ws.merge_cells(f’A{sum_row_start}:A{sum_row_end}’) break row = sum_row_end + 1def main(): # 根據情況修改代碼 in_file_name = ’In.xlsx’ processing_sheet = ’Sheet1’ path_name = ’D:UsersDesktopTemp’ out_file_name = ’Out.xlsx’ wb = openpyxl.load_workbook(filename=os.path.join(path_name,in_file_name)) total_amount(wb[processing_sheet]) wb.save(os.path.join(path_name,out_file_name))if __name__==’__main__’: main()說明

本功能用到了openpyxl模塊,更多Excel操作請見官網

本代碼不支持Excel中間有空行的情況,最后有空行無影響

f’A{sum_row_start}’這樣的代碼用到了f-string功能,若python版本低于3.6,需改為’A’+str(sum_row_start)或其它形式

補充:Python3 Pandas DataFrame 對某一列求和

在操作pandas的DataFrame的時候,常常會遇到某些列是字符串,某一些列是數值的情況,如果直接使用df_obj.apply(sum)往往會出錯

使用如下方式即可對其中某一列進行求和

dataf_test1[’diff’].sum() // diff為要求和的列

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: python
相關文章:
主站蜘蛛池模板: 校服厂家,英伦校服定做工厂,园服生产定制厂商-东莞市艾咪天使校服 | 全自动五线打端沾锡机,全自动裁线剥皮双头沾锡机,全自动尼龙扎带机-东莞市海文能机械设备有限公司 | 北京森语科技有限公司-模型制作专家-展览展示-沙盘模型设计制作-多媒体模型软硬件开发-三维地理信息交互沙盘 | 单螺旋速冻机-双螺旋-流态化-隧道式-食品速冻机厂家-广州冰泉制冷 | 光伏家 - 太阳能光伏发电_分布式光伏发电_太阳能光伏网 | 12cr1mov无缝钢管切割-15crmog无缝钢管切割-40cr无缝钢管切割-42crmo无缝钢管切割-Q345B无缝钢管切割-45#无缝钢管切割 - 聊城宽达钢管有限公司 | 风化石头制砂机_方解石制砂机_瓷砖石子制砂机_华盛铭厂家 | 慈溪麦田广告公司,提供慈溪广告设计。| 尊享蟹太太美味,大闸蟹礼卡|礼券|礼盒在线预订-蟹太太官网 | 变色龙云 - 打包app_原生app_在线制作平台_短链接_ip查询 | 高低温万能试验机_拉力试验机_拉伸试验机-馥勒仪器科技(上海)有限公司 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 电缆隧道在线监测-智慧配电站房-升压站在线监测-江苏久创电气科技有限公司 | 造价工程师网,考试时间查询,报名入口信息-网站首页 | 自清洗过滤器_全自动过滤器_全自动反冲洗过滤器_量子过滤器-滑漮滴 | 不锈钢复合板|钛复合板|金属复合板|南钢集团安徽金元素复合材料有限公司-官网 | 双效节能浓缩器-热回流提取浓缩机组-温州市利宏机械 | 浇注料-高铝砖耐火砖-郑州凯瑞得窑炉耐火材料有限公司 | 硅胶布|电磁炉垫片|特氟龙胶带-江苏浩天复合材料有限公司 | 色油机-色母机-失重|称重式混料机-称重机-米重机-拌料机-[东莞同锐机械]精密计量科技制造商 | 浙江上沪阀门有限公司| 山东钢衬塑罐_管道_反应釜厂家-淄博富邦滚塑防腐设备科技有限公司 | 电主轴-高速精密电主轴-高速电机厂家-瑞德沃斯品牌有限公司 | 欧盟ce检测认证_reach检测报告_第三方检测中心-深圳市威腾检验技术有限公司 | 婚博会2024时间表_婚博会门票领取_婚博会地址-婚博会官网 | 液压扳手-高品质液压扳手供应商 - 液压扳手, 液压扳手供应商, 德国进口液压拉马 | 七维官网-水性工业漆_轨道交通涂料_钢结构漆 | 搪瓷搅拌器,搪玻璃搅拌器,搪玻璃冷凝器_厂家-淄博越宏化工设备 | 扬尘在线监测系统_工地噪声扬尘检测仪_扬尘监测系统_贝塔射线扬尘监测设备「风途物联网科技」 | 淋巴细胞分离液_口腔医疗器材-精欣华医疗器械(无锡)有限公司 | 成都装修公司-成都装修设计公司推荐-成都朗煜装饰公司 | 冷却塔改造厂家_不锈钢冷却塔_玻璃钢冷却塔改造维修-广东特菱节能空调设备有限公司 | 广州云仓代发-昊哥云仓专业电商仓储托管外包代发货服务 | 睿婕轻钢别墅_钢结构别墅_厂家设计施工报价 | 物联网卡_物联网卡购买平台_移动物联网卡办理_移动联通电信流量卡通信模组采购平台? | 电动葫芦-河北悍象起重机械有限公司 | 斗式提升机_链式斗提机_带式斗提机厂家无锡市鸿诚输送机械有限公司 | 济南侦探调查-济南调查取证-山东私家侦探-山东白豹调查咨询公司 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 老城街小面官网_正宗重庆小面加盟技术培训_特色面馆加盟|牛肉拉面|招商加盟代理费用多少钱 | 浙江浩盛阀门有限公司| 工业机械三维动画制作 环保设备原理三维演示动画 自动化装配产线三维动画制作公司-南京燃动数字 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 |