<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
如果你經常與Excel或Word打交道,那麼從兩份表格/檔案中找到不一樣的元素是一件讓人很頭疼的工作,當然網上有很多方法、第三方軟體教你如何對比兩份檔案。本文就將以兩份真實的Excel/Word檔案為例,講解如何使用Python光速對比並提取檔案中的不同之處!
為了方便說明,我建立了一個簡單的Excel用於範例
可以看到上方兩個Excel表格中共有五處不同,現在我們使用Python來快速定位這五處不同,這次不需要openpyxl,使用Pandas就能輕鬆搞定,首先匯入相關庫並讀取資料
import pandas as pd import numpy as np df1 = pd.read_excel('data1.xlsx') df2 = pd.read_excel('data2.xlsx')
其實在Pandas中一行程式碼就能找到兩個DataFrame的不同
可以看到,如果一樣的資料就是NaN,而變化的資料則以它的值儲存,但是如果這麼做的話,我們僅僅找到資料不同的位置,並且資料量大的話盯著找到不同也挺消耗時間的,所以我們進一步研究。先換一種方式找到不同的值
接著再使用NumPy根據True/False定位元素位置,同時將值的改變寫入原表格並儲存
rows,cols=np.where(comparison_values==False) for item in zip(rows,cols): df1.iloc[item[0], item[1]] = '{} --> {}'.format(df1.iloc[item[0], item[1]],df2.iloc[item[0], item[1]]) df1.to_excel('diff.xlsx',index=False,header=True)
現在就生成了一個新的Excel來提示我們哪裡發生了變化
這樣看起來就舒服了很多(高亮是手動的),當然在進行兩個Excel比較的時候一定要注意這兩個Excel的資料格式要差不多!
兩份Word比較起來相對於Excel就困難一點。首先我們還是建立兩份有區別的Word檔案,內容取自百度百科中的Python介紹[1]
左邊的為原始word右邊的word是我修改了幾處的檔案, 現在我們用Python來快速找到兩份檔案的不同。讀取檔案使用到的是docx庫[2] ,因為涉及到中文所以我們需要先讀取docx檔案,然後分段再根據標點符號分句,具體程式碼如下
def getText(wordname): ''' 提取文字 ''' d = Document(wordname) texts = [] for para in d.paragraphs: texts.append(para.text) return texts def is_Chinese(word): ''' 識別中文 ''' for ch in word: if 'u4e00' <= ch <= 'u9fff': return True return False def msplit(s, seperators = ',|.|?|,|。|?|!|、'): ''' 根據標點符號分句 ''' return re.split(seperators, s) def readDocx(docfile): ''' 讀取檔案 ''' print(f"======正在讀取{docfile}======") paras = getText(docfile) segs = [] for p in paras: temp = [] for s in msplit(p): if len(s) > 2: temp.append(s.replace(' ', "")) if len(temp) > 0: segs.append(temp) return segs
使用上面這段程式碼讀一下兩個word試試
可以看到我們的word檔案已經按照不同段落分好句存在兩層list中,所以接下來的問題就轉換為比較兩個list,而這又是我們熟悉的
def comparsion(doc1,doc2,p,s): if doc1 == doc2: print('兩個word完全一致') else: if doc1[p][s] != doc2[p][s]: print(f"第{p+1}段,第{s+1}句不相同: {doc1[p][s]} ----> {doc2[p][s]}")
上面的判斷為最簡單的形式:兩個word中僅有文字改變,而段落、句子數量均沒有改變,我們來試一下效果
只要一秒,Python就找到了兩份word檔案之間的不同之處並定位!
通過介紹如何使用Python來對兩個Excel/Word檔案進行比較,我想你應該體會到了Python的強大之處,其實思路無非就是讀取檔案、定位之處並標記。但更重要的是你在日常工作學習時是否可以想到用Python去解決那些繁瑣費力的流程,學會使用Python合理偷懶才是我寫辦公自動化系列的目的。
到此這篇關於Python實現光速定位並提取兩個檔案的不同之處的文章就介紹到這了,更多相關Python檔案不同之處內容請搜尋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