<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
阿里雲產品費用巡檢,一般流程是登入賬號,再逐項核對填寫。雖然簡單,但如果帳號多表格多,帳號間的資料有關聯,填寫起來就比較費力氣。幾張表格,可能從下載資料到核寫完畢,輾轉半個小時。
因此在保留excel原檔案格式不變的基礎上,自動填寫相關數值變得重要。
python操作excel的模組多,xlrd,pandas,xlwings,openpyxl
。經常搞不清這麼多功能類似的模組有什麼區別,這裡發現xlwings可以派上用場,因為我有個保留excel格式的需求,檔案格式:
表1-1
注意:主要修改第10、11行,其它不變。
通過爬蟲登入阿里雲,下載資料寫入csv。帶上日期,如data_07-25.csv
表1-2
爬蟲指令碼
# -*- coding: utf-8 -*- from selenium import webdriver from selenium.webdriver.chrome.options import Options import time,os,glob,csv from datetime import datetime options = Options() options.add_argument('--disable-infobars') options.add_argument('--incognito') # options.add_argument('--headless') bro = webdriver.Chrome(executable_path='C:drf2drf2chromedriver.exe', chrome_options=options) bro.maximize_window() bro.get('https://www.aliyun.com/') bro.implicitly_wait(10) #點選首頁的登入按鈕 bro.find_element_by_xpath('//*[@id="J_3207526240"]/div/div/div[1]/div[2]/div[2]/a[4]').click() time.sleep(1) #點選RAM使用者 bro.find_element_by_xpath('//*[@id="root"]/div/div[2]/div/div[2]/div[1]/div[2]/div[2]/div/div[2]/div[2]/span/div').click() u = bro.find_element_by_xpath('//*[@id="--aliyun-xconsole-app"]/div[1]/div[2]/div/div/div[1]/div[2]/div/div/div[2]/div/div/div/form/div[1]/div[2]/div[1]/span/input') #使用者名稱 u.send_keys('') time.sleep(5) #點選下一步 bro.find_element_by_xpath('//*[@id="--aliyun-xconsole-app"]/div[1]/div[2]/div/div/div[1]/div[2]/div/div/div[2]/div/div/div/form/div[5]/button/span').click() p = bro.find_element_by_xpath('//*[@id="--aliyun-xconsole-app"]/div[1]/div[2]/div/div/div[1]/div[2]/div/div/div[2]/div/div/div/form/div[2]/div[2]/span/input') #密碼 p.send_keys('') time.sleep(5) # 點選登入按鈕 bro.find_element_by_xpath('//*[@id="--aliyun-xconsole-app"]/div[1]/div[2]/div/div/div[1]/div[2]/div/div/div[2]/div/div/div/form/div[5]/button/span').click() time.sleep(3) # 點選控制檯 bro.find_element_by_xpath( '//*[@id="J_3207526240"]/div/div/div[1]/div[2]/div[2]/a[3]').click() time.sleep(6) #切換視窗 bro.switch_to.window(bro.window_handles[-1]) # 點選費用 bro.find_element_by_xpath( '/html/body/div[1]/div/div/nav/div[1]/a').click() time.sleep(3) bro.switch_to.window(bro.window_handles[-1]) available_credit = bro.find_element_by_xpath('//*[@id="app__home"]/div/div/div/div[2]/div[1]/div[1]/div[2]/div/div[1]/span[1]/span').text time.sleep(3) #點選帳單詳情 bro.find_element_by_xpath( '//*[@id="root-app"]/div[1]/div/div[6]/div[3]/a').click() time.sleep(1.5) #點選產品量價彙總 bro.find_element_by_xpath( '//*[@id="app__ent-expense"]/div/div/div[1]/div[1]/div/div/div/ul/li[4]/div/span').click() time.sleep(1.5) trs = bro.find_elements_by_xpath('//tbody/tr[position()> 1]') for f in os.listdir('C:/Users/Administrator/Desktop/費用巡檢/'): if f.startswith('fee'): os.remove('C:/Users/Administrator/Desktop/費用巡檢/%s' % f) with open('C:/Users/Administrator/Desktop/費用巡檢/fee_%s.csv' % datetime.now().__format__('%m-%d'), 'a+', newline='', encoding='gb18030') as f: f_csv = csv.writer(f) f_csv.writerow(['可用額度',available_credit.split(' ')[1]]) for tr in trs: tr = tr.text.split('n') f_csv.writerow([tr[0],tr[1].split(' ')[1]]) bro.quit()
為了方便識別,變數名直接用中文了
import pandas as pd df = pd.read_csv('data_%s.csv' % datetime.now().__format__('%m-%d'), encoding='gbk', names=['內容', '金額']) 內容安全 = eval(df.iloc[5, 1]) 系統簡訊 = 0 雲伺服器ECS流量 = eval(df.iloc[4, 1]) 物件儲存 = eval(df.iloc[8, 1]) 檔案儲存 = eval(df.iloc[6, 1]) 視訊點播 = eval(df.iloc[11, 1]) 巨量資料 = eval(df.iloc[2, 1]) + eval(df.iloc[7, 1]) CDN = eval(df.iloc[1, 1]) 紀錄檔服務 = eval(df.iloc[10, 1]) 塊儲存 = eval(df.iloc[3, 1]) 合計 = round(內容安全 + 系統簡訊 + 雲伺服器ECS流量 + 物件儲存 + 檔案儲存 + 視訊點播 + 巨量資料 + CDN + 紀錄檔服務 + 塊儲存, 2) 餘額 = eval(df.iloc[0, 1].replace(',', ''))
import xlwings as xw from datetime import datetime import os app = xw.App(visible=False,add_book=False) app.display_alerts = False app.screen_updating = False wb = app.books.open(filename) ws = wb.sheets[0]
# 修改第10行,expand引數可以方便的按順序一行寫完 ws.range('B10').options(expand='table').value = [內容安全, 系統簡訊, 雲伺服器ECS流量, 物件儲存, 檔案儲存, 視訊點播, 巨量資料, CDN, 紀錄檔服務, 塊儲存, 合計, 餘額] # 修改第11行 ws.range('e41').value = '本月(%s月)已使用%s元,實際賬戶餘額為%s元。' % (datetime.now().month, 合計, 餘額) path = 'D:/桌面/巡檢/%s' % datetime.now().__format__('%m-%d') if not os.path.exists(path): os.mkdir(path) wb.save(os.path.join(path,'教育費用_%s.xlsx' % datetime.now().__format__('%m-%d'))) wb.close() app.quit()
通過使用xlwings自動修改表格,我的6張表格從原先的操作半小時,到現在滑鼠duang~duang~duang~幾下即可做好。減少上百次的複製貼上點選後,工作更輕鬆了。
到此這篇關於Python操作xlwings的範例詳解的文章就介紹到這了,更多相關Python xlwings內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45