如何用python整理附件
目前我的文件夾中有500多份簡歷,如果我想知道一些信息,比如學(xué)校,學(xué)歷之類的,我需要打開每一份word去查看,太耗時(shí)間了。這個(gè)時(shí)候python需要出馬了。
目標(biāo)
目前類似截圖中的word有600+,想簡單的進(jìn)行整理:

可以整理出一份excel用于導(dǎo)航(類似目錄),可以通過excel來快速定位到所要的附件,如下圖效果:

具體實(shí)現(xiàn)
有了目標(biāo),就具體說說如何實(shí)現(xiàn)的,整理思路還是比較簡單的,就是遍歷所有的word文件,將word中關(guān)鍵的信息獲取到并保存到excel中。
這里列下主要用到的模塊:
import xlsxwriter import subprocess import os import docx import sys import re
xlsxwriter主要用來操作excel,xlsxwriter只能用來寫,效率上比xlwt要高,數(shù)據(jù)量不多,用xlwt也ok。
subprocess主要用來調(diào)用命令行,因?yàn)閐ocx模塊無法解析doc的word文件,所以在解析前將doc的文件轉(zhuǎn)換成docx文件。
os主要用于遍歷文件夾獲取文件。
docx主要用來解析word文檔。
規(guī)范下文件名
首先我們先規(guī)范下文件名稱,因?yàn)樵谑褂胹ubprocess.call調(diào)用命令時(shí),空格,特殊符號之類的沒辦法轉(zhuǎn)義導(dǎo)致報(bào)錯(cuò),所以干脆在之前就清理掉這個(gè)潛在問題。
def remove_doc_special_tag():
for filename in os.listdir(path):
otherName = re.sub("[\s+\!\/_,$%^*(+\"\')]+|[+——()?【】“”!,。?、~@#¥%……&*()]+", "",filename)
os.rename(os.path.join(path,filename),os.path.join(path,otherName))
遍歷文件
之后我們就可以開始正題,遍歷每個(gè)文件進(jìn)行解析:
path='/Users/cavin/Desktop/files' for filename in os.listdir(path): ...具體邏輯...
這里碰到一個(gè)問題,首先是docx模塊無法解析doc的word文檔,由于又是使用的mac,所以也無法使用win32com模塊,這個(gè)問題就比較尷尬,后來google發(fā)現(xiàn)可以通過命令將doc轉(zhuǎn)換成docx。
這里注意下轉(zhuǎn)換后的docx文件樣式是丟失的,但這不影響我獲取文本信息。
于是就有了這段代碼,如果是doc的文件,優(yōu)先轉(zhuǎn)換成docx,待解析完之后再移除掉。
if filename.endswith('.doc'):
subprocess.call('textutil -convert docx {0}'.format(fullname),shell=True)
fullname=fullname[:-4]+".docx"
sheetModel= etl_word_files(fullname)#解析文本邏輯
subprocess.call('rm {0}'.format(fullname),shell=True) #移除轉(zhuǎn)換的文件
解析word文件
接下來就是解析文件了,通過docx模塊很容易實(shí)現(xiàn),具體的解析邏輯就不貼了,就是遍歷每一行,根據(jù)一些關(guān)鍵字,符號來截取數(shù)據(jù)(每個(gè)簡歷格式基本上差不多的)
doc = docx.Document(fullname) for para in doc.paragraphs: print(para.text) ...具體解析邏輯...
填充excel
解析完的數(shù)據(jù)就可以直接填充excel了:
workbook = xlsxwriter.Workbook('report_list.xlsx')
worksheet = workbook.add_worksheet('list')
worksheet.write(0,0, '序號')
worksheet.write(0,1, '姓名')
worksheet.write(0,2, '性別')
worksheet.write(0,3, '年齡')
worksheet.write(0,4, '籍貫')
worksheet.write(0,5, '目前所在地')
worksheet.write(0,6, '學(xué)歷')
worksheet.write(0,7, '學(xué)校')
worksheet.write(0,8, '公司')
worksheet.write(0,9, '職位')
worksheet.write(0,10, '文檔鏈接')
這里主要說下文檔鏈接的填充,由于是要給其他人的,只要保證附件和excel在同一個(gè)文件夾下,采用相對路徑的方式來實(shí)現(xiàn),可以使用Excel的函數(shù)HYPERLINK:
worksheet.write(index,10, '=HYPERLINK(\"./'+filename+'\",\"附件\")')
問題點(diǎn)
到這里,基本上可以實(shí)現(xiàn)相應(yīng)的功能了,但不是很完美,主要是word中的格式不標(biāo)準(zhǔn),沒有很好的方式去準(zhǔn)確獲取到我要的數(shù)據(jù),但主要的姓名學(xué)校之類的大多數(shù)都抓到了,也算減輕點(diǎn)任務(wù)啦。
總結(jié)
利用python還是減少了一定的重復(fù)勞動,但面對一些不標(biāo)準(zhǔn)的東東貌似還沒有很好的方式。
雖然可以增加邏輯來兼容這些不標(biāo)準(zhǔn),但顯然這個(gè)付出和產(chǎn)出就有點(diǎn)不成正比了。
利用好手上的工具去提高效率才是真的,至于是傻瓜式的重復(fù)工作,還是通過代碼來減少重復(fù)勞動,就看你自己怎么看啦。
- python3+mysql查詢數(shù)據(jù)并通過郵件群發(fā)excel附件
- Python3實(shí)現(xiàn)帶附件的定時(shí)發(fā)送郵件功能
- python實(shí)現(xiàn)自動發(fā)送郵件發(fā)送多人、群發(fā)、多附件的示例
- Python3實(shí)現(xiàn)發(fā)送QQ郵件功能(附件)
- Python實(shí)現(xiàn)讀取郵箱中的郵件功能示例【含文本及附件】
- 詳解python實(shí)現(xiàn)讀取郵件數(shù)據(jù)并下載附件的實(shí)例
- Python實(shí)現(xiàn)Smtplib發(fā)送帶有各種附件的郵件實(shí)例
- python實(shí)現(xiàn)發(fā)送郵件及附件功能
- Python中Django發(fā)送帶圖片和附件的郵件
- Python發(fā)送以整個(gè)文件夾的內(nèi)容為附件的郵件的教程
- 使用Python發(fā)送郵件附件以定時(shí)備份MySQL的教程
- 用Python實(shí)現(xiàn)一個(gè)簡單的能夠發(fā)送帶附件的郵件程序的教程
- 二種python發(fā)送郵件實(shí)例講解(python發(fā)郵件附件可以使用email模塊實(shí)現(xiàn))
- python發(fā)送郵件的實(shí)例代碼(支持html、圖片、附件)
相關(guān)文章
python程序中斷然后接著中斷代碼繼續(xù)運(yùn)行問題
這篇文章主要介紹了python程序中斷然后接著中斷代碼繼續(xù)運(yùn)行問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
python2和python3實(shí)現(xiàn)在圖片上加漢字的方法
python2和python3實(shí)現(xiàn)在圖片上加漢字,最主要的區(qū)別還是內(nèi)部編碼方式不一樣導(dǎo)致的,在代碼上表現(xiàn)為些許的差別。這篇文章主要介紹了python2和python3實(shí)現(xiàn)在圖片上加漢字,需要的朋友可以參考下2019-08-08
Python中命令行參數(shù)argparse模塊的使用
argparse是python自帶的命令行參數(shù)解析包,可以用來方便的服務(wù)命令行參數(shù)。本文將通過示例和大家詳細(xì)講講argparse的使用,需要的可以參考一下2023-02-02
通過python爬蟲mechanize庫爬取本機(jī)ip地址的方法
python中的mechanize算是一個(gè)比較古老的庫了,在python2的時(shí)代中,使用的多一些,在python3以后就很少使用了,現(xiàn)在已經(jīng)是2202年了,可能很多人都沒聽說過mechanize,這不要緊,我們先來簡單的講解一下,如何使用mechanize,感興趣的朋友一起看看吧2022-08-08
Python利用PyQt6開發(fā)一個(gè)全能的任務(wù)管理器
在數(shù)字化辦公時(shí)代,我們每天都要重復(fù)執(zhí)行大量機(jī)械性操作,這些操作不僅浪費(fèi)時(shí)間,還容易因人為疏忽出錯(cuò),所以本文就來使用PyQt6開發(fā)一個(gè)升級的自動化任務(wù)管理器吧2025-04-04
Python MySQL數(shù)據(jù)庫連接池組件pymysqlpool詳解
這篇文章主要跟大家介紹了關(guān)于Python MySQL數(shù)據(jù)庫連接池組件pymysqlpool的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-07-07
pandas 時(shí)間格式轉(zhuǎn)換的實(shí)現(xiàn)
這篇文章主要介紹了pandas 時(shí)間格式轉(zhuǎn)換的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07

