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

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

Python 實現自動化Excel報表的步驟

瀏覽:126日期:2022-06-23 15:32:38

好幾個月沒有寫筆記了, 并非沒有積累, 而是有點懶了. 想想還是要續上, 作為工作成長的一部分哦.

最近有做一些報表, 但一直找不到一個合適的報表工具, 又實在不想寫前端, 后端... 思來想去, 感覺 Excel 就一定程度上能做可視化的, 除了不能動態交互外, 其他都挺好. 今天分享的就是一個關于如何用 Py 來自動化Excel 報表, 解放雙手, 提高工作效率哦.

總體解決方案

Python 實現自動化Excel報表的步驟

輸出報表

當然是測試用的假數據啦.

Python 實現自動化Excel報表的步驟

自動化Py腳本

基本思路: 1. 準備模板數據需要的 SQL 2. 用 Pandas 連接 數據庫 并執行 SQL, 返回 DataFrame 3. 用 Xlwings 直接打開 Excel, 并將這些 DataFrame 填充到 寫死的 單元格4. 保存并退出

具體代碼如下哦:

import pandas as pd import xlwings as xwimport pymssql# 各品類月同期 def get_last_year_sale(start_date, end_date): '''各品類同期銷量, 對比19年''' sql_01 = f''' SELECT 品類 , SUM(數量) AS QTY FROM XXX WHERE 是否電商 = 1 AND 銷售時間 BETWEEN DATEADD(YEAR, -2, ’{start_date}’) AND DATEADD(YEAR, -2, ’{end_date}’) GROUP BY 品類 ''' df = pd.read_sql(sql_01, con=con) df_xtc = df[df[’品類’] == ’A品類’][[’品類’, ’QTY’]] df_bbk = df[df[’品類’] == ’B品類’][[’品類’, ’QTY’]] return df_xtc, df_bbk def get_anget_sale(start_date, end_date): '''返回各品類, 各區域的時間段銷量''' sql = f''' SELECT 品類 , AGENT , SUM(數量) AS QTY , ROW_NUMBER()OVER(PARTITION BY 品類 ORDER BY SUM(數量) DESC) MY_RANK FROM XXX WHERE 是否電商 = 1 AND 銷售時間 BETWEEN ’{start_date}’ AND ’{end_date}’ GROUP BY AGENT, 品類 ''' df = pd.read_sql(sql, con=con) df_xtc = df[df[’品類’] == ’A品類’][[’AGENT’, ’QTY’]] df_bbk = df[df[’品類’] == ’B品類’][[’AGENT’, ’QTY’]] df_pad = df[df[’品類’] == ’C品類’][[’AGENT’, ’QTY’]] return df_xtc, df_bbk, df_pad def get_machine_sale(start_date, end_date): '''返回各品類, 各區域的時間段銷量''' sql = f''' SELECT 品類 , 機型 , SUM(數量) AS QTY , ROW_NUMBER()OVER(PARTITION BY 品類 ORDER BY SUM(數量) DESC) MY_RANK FROM V_REALSALE WHERE 是否電商 = 1 AND 銷售時間 BETWEEN ’{start_date}’ AND ’{end_date}’ GROUP BY 機型, 品類 ''' df = pd.read_sql(sql, con=con) df_xtc = df[df[’品類’] == ’A品類’][[’機型’, ’QTY’]] df_bbk = df[df[’品類’] == ’B品類’][[’機型’, ’QTY’]] return df_xtc, df_bbk # main con = pymssql.connect(’xxxxx’, ’sxxx’, ’xxxxxx’, ’xxxxx’)# 基礎配置: 根據用戶輸入當前日期, 輸出當月, 當季度第一天 print('歡迎哦, 此小程序專門為XX看板做數據自動更新呢~')print()today = input('請輸入截止日期(昨天), 形如: 2021/5/20 按回車結束: ')if len(today.split(’/’)) != 3: raise '日期格式輸入錯誤!!, 請按照形如 ’2021/5/20’的格式重新輸入'else: m_cur = today.split(’/’)[1] m_first_day = ’2021/’ + m_cur + ’/1’# 季度第一天 if m_cur in (’1’, ’01’, ’2’, ’02’, ’3’, ’03’): q_time_start = ’2021/1/1’ elif m_cur in (’4’, ’04’, ’5’, ’05’, ’6’, ’06’): q_time_start = ’2021/4/1’ elif m_cur in (’7’, ’07’, ’8’, ’08’, ’9’, ’09’): q_time_start = ’2021/7/1’else: q_time_start = ’2021/10/1’print()print('正在開始更新....')print('提示, 接下看到閃退, 是正常現象, 就程序模擬人去打開文件, 填充數據, 不要緊張哦~~~')# 去年月, 季度同期 df_mm_xtc, df_mm_bbk = get_last_year_sale(m_first_day, today)df_qq_xtc, df_qq_bbk = get_last_year_sale(q_time_start, today)# 當月各地區累積銷量df_m_xtc, df_m_bbk, df_m_pad = get_anget_sale(m_first_day, today)# 各地區當季度銷量 df_q_xtc, df_q_bbk, df_q_pad = get_anget_sale(q_time_start, today)# 各機型當季度銷量 df_q_type_xtc, df_q_type_bbk = get_machine_sale(q_time_start, today) # 過濾掉 銷量為0的型號 df_q_type_xtc = df_q_type_xtc[df_q_type_xtc.QTY > 0]df_q_type_xtc.replace(’Z6áÛ·å°æ’, ’Z6巔峰版’, inplace=True)df_q_type_bbk = df_q_type_bbk[df_q_type_bbk.QTY > 0]# 打開excel 模板 等待數據填充 app = xw.App(visible=True, add_book=False)app.display_alerts = False # 關閉一些提示信息,可以加快運行速度。 默認為 True。app.screen_updating = Truewb = app.books.open('XXX_全品類_看板.xlsx')data_sht = wb.sheets[’數據’]# 19年當月同期銷量data_sht.range(’B9’).value = df_mm_xtc.valuesdata_sht.range(’G9’).value = df_mm_bbk.values# 當季度同比data_sht.range(’B10’).value = df_qq_xtc.valuesdata_sht.range(’G10’).value = df_qq_bbk.values# 填充各品類當月銷量, 注意單元格是寫死的哦data_sht.range(’I72’).value = df_m_xtc.valuesdata_sht.range(’T72’).value = df_m_bbk.valuesdata_sht.range(’AE72’).value = df_m_pad.values# 填充當季度銷量, 同理是寫死的data_sht.range(’A54’).value = df_q_xtc.valuesdata_sht.range(’F54’).value = df_q_bbk.valuesdata_sht.range(’K54’).value = df_q_pad.values# 填充當季度各型號, 同理是寫死的data_sht.range(’A21’).value = df_q_type_xtc.valuesdata_sht.range(’F21’).value = df_q_type_bbk.valueswb.save()app.quit()print()print('~~更新結束了哦~~')print()input('請按任意鍵退出~~')print()print(’BYE~~ 人生若只如初見呢~~’)打包 EXE 桌面小程序

最好用一個純凈的 虛擬環境打包.

終端命令: python -m venv 虛擬環境名稱

然后進入腳本目錄下, 進行打包哦.

pyinstaller main.py -F

Python 實現自動化Excel報表的步驟

打包成功后的樣子.

Python 實現自動化Excel報表的步驟

雙擊運行即可哦.

Python 實現自動化Excel報表的步驟

這時候再重新打開該目錄下的 Excel 模板, 發現數據已經自動更新了.

我現在真的感受到, 用開發的思維做一些腳本工具, 真的會極大提高我現在當文員的很多重復性工作哦!

以上就是Python 實現自動化Excel報表的步驟的詳細內容,更多關于python 自動化Excel報表的資料請關注好吧啦網其它相關文章!

標簽: python
相關文章:
主站蜘蛛池模板: 上海软件开发-上海软件公司-软件外包-企业软件定制开发公司-咏熠科技 | 钢结构厂房造价_钢结构厂房预算_轻钢结构厂房_山东三维钢结构公司 | 天津货架厂_穿梭车货架_重型仓储货架_阁楼货架定制-天津钢力仓储货架生产厂家_天津钢力智能仓储装备 | 胜为光纤光缆_光纤跳线_单模尾纤_光纤收发器_ODF光纤配线架厂家直销_北京睿创胜为科技有限公司 - 北京睿创胜为科技有限公司 | 蜂窝块状沸石分子筛-吸附脱硫分子筛-萍乡市捷龙环保科技有限公司 | 高中学习网-高考生信息学习必备平台 | 太原装修公司_山西整装家装设计_太原室内装潢软装_肖邦家居 | 电加热导热油炉-空气加热器-导热油加热器-翅片电加热管-科安达机械 | 横河变送器-横河压力变送器-EJA变送器-EJA压力变送器-「泉蕴仪表」 | 赛默飞Thermo veritiproPCR仪|ProFlex3 x 32PCR系统|Countess3细胞计数仪|371|3111二氧化碳培养箱|Mirco17R|Mirco21R离心机|仟诺生物 | 磁力抛光研磨机_超声波清洗机厂家_去毛刺设备-中锐达数控 | 印刷人才网 印刷、包装、造纸,中国80%的印刷企业人才招聘选印刷人才网! | 逗网红-抖音网红-快手网红-各大平台网红物品导航 | 胜为光纤光缆_光纤跳线_单模尾纤_光纤收发器_ODF光纤配线架厂家直销_北京睿创胜为科技有限公司 - 北京睿创胜为科技有限公司 | 北京四合院出租,北京四合院出售,北京平房买卖 - 顺益兴四合院 | 防火阀、排烟防火阀、电动防火阀产品生产销售商-德州凯亿空调设备有限公司 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 购买舔盐、舔砖、矿物质盐压块机,鱼饵、鱼饲料压块机--请到杜甫机械 | 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 耐腐蚀泵,耐腐蚀真空泵,玻璃钢真空泵-淄博华舜耐腐蚀真空泵有限公司 | FFU_空气初效|中效|高效过滤器_空调过滤网-广州梓净净化设备有限公司 | 萃取箱-萃取槽-PVC萃取箱厂家-混合澄清槽- 杭州南方化工设备 | 深圳3D打印服务-3D打印加工-手板模型加工厂-悟空打印坊 | 企业微信营销_企业微信服务商_私域流量运营_艾客SCRM官网 | 英超直播_英超免费在线高清直播_英超视频在线观看无插件-24直播网 | 铸钢件厂家-铸钢齿轮-减速机厂家-淄博凯振机械有限公司 | 除甲醛公司-甲醛检测-广西雅居环境科技有限公司 | 物联网卡_物联网卡购买平台_移动物联网卡办理_移动联通电信流量卡通信模组采购平台? | 北京乾茂兴业科技发展有限公司| 搪瓷反应釜厂家,淄博搪瓷反应釜-淄博卓耀 | HYDAC过滤器,HYDAC滤芯,现货ATOS油泵,ATOS比例阀-东莞市广联自动化科技有限公司 | 锯边机,自动锯边机,双面涂胶机-建业顺达机械有限公司 | FFU_空气初效|中效|高效过滤器_空调过滤网-广州梓净净化设备有限公司 | FFU_空气初效|中效|高效过滤器_空调过滤网-广州梓净净化设备有限公司 | 日本SMC气缸接头-速度控制阀-日本三菱伺服电机-苏州禾力自动化科技有限公司 | 砂尘试验箱_淋雨试验房_冰水冲击试验箱_IPX9K淋雨试验箱_广州岳信试验设备有限公司 | 小型数控车床-数控车床厂家-双头数控车床 | 巨野电机维修-水泵维修-巨野县飞宇机电维修有限公司 | 壹作文_中小学生优秀满分作文大全| SDG吸附剂,SDG酸气吸附剂,干式酸性气体吸收剂生产厂家,超过20年生产使用经验。 - 富莱尔环保设备公司(原名天津市武清县环保设备厂) |