利用python對(duì)Excel中的特定數(shù)據(jù)提取并寫(xiě)入新表的方法
最近剛開(kāi)始學(xué)python,正好實(shí)習(xí)工作中遇到對(duì)excel中的數(shù)據(jù)進(jìn)行處理的問(wèn)題,就想到利用python來(lái)解決,也恰好練手。
實(shí)際的問(wèn)題是要從excel表中提取日期、郵件地址和時(shí)間,然后統(tǒng)計(jì)在一定時(shí)間段內(nèi)某個(gè)人在某個(gè)項(xiàng)目上用了多少時(shí)間,最后做成一張數(shù)據(jù)透視表(這是問(wèn)題的大致意思)。
首先要做的就是數(shù)據(jù)提取了,excel中本身有一個(gè)text to column的功能,但是對(duì)列中規(guī)律性不好的數(shù)據(jù)處理效果很差,不能分割出想要的數(shù)據(jù),所以我果斷選擇用python來(lái)完成。
要用的庫(kù)一個(gè)是對(duì)excel讀寫(xiě)處理的,一個(gè)事正則表達(dá)式的庫(kù)。
因?yàn)閤lwt和xlrd只能對(duì)03版以前的excel處理,所以我選擇了openpyxl。
以下代碼就是自己敲的,寫(xiě)了對(duì)日期和郵件地址的提取,最后出來(lái)效果不錯(cuò),僅供大家參考,歡迎交流與改進(jìn)。
import openpyxl
import re
def Exceldivide(file_dir):
wb=openpyxl.load_workbook(file_dir) #打開(kāi)原有的excel表
sheet=wb.get_sheet_by_name('Sheet1')
tuple(sheet['A1':'C3'])
wb.create_sheet('Sheet2') #新建一個(gè)表
sheet2=wb.get_sheet_by_name('Sheet2')
tuple(sheet2['A1':'C3'])
L1=re.compile(r'\d\d/\d\d/\d\d\d\d') #日期格式
L2=re.compile(r'[a-zA-Z0-9_]+@[a-zA-Z0-9-]+.com') #郵件格式
l1=[]
l2=[]
for rows in sheet['A1':'C3']: #提取日期和郵件數(shù)據(jù)
for cell in rows:
A=L1.search(cell.value)
a=A.group()
B=L2.search(cell.value)
b=B.group()
for rows in sheet2['A1':'A9']: #把日期數(shù)據(jù)寫(xiě)入新表
for cell in rows:
cell.value=a
print(cell.coordinate,cell.value)
for rows in sheet2['B1':'B9']: #把郵件數(shù)據(jù)寫(xiě)入新表
for cell in rows:
cell.value=b
print(cell.coordinate,cell.value)
return wb
g=Exceldivide('C:\\Users\\Desktop\\111_copy.xlsx')
g.save('C:\\Users\\Desktop\\111_copy.xlsx') #保存
以上這篇利用python對(duì)Excel中的特定數(shù)據(jù)提取并寫(xiě)入新表的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python 利用matplotlib在3D空間繪制二次拋物面的案例
這篇文章主要介紹了python 利用matplotlib在3D空間繪制二次拋物面的案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02
python從Oracle讀取數(shù)據(jù)生成圖表
這篇文章主要介紹了python如何從Oracle讀取數(shù)據(jù)生成圖表,幫助大家更好的利用python處理數(shù)據(jù),感興趣的朋友可以了解下2020-10-10
python保留格式匯總各部門excel內(nèi)容的實(shí)現(xiàn)思路
這篇文章主要介紹了python保留格式匯總各部門excel內(nèi)容,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
Django學(xué)習(xí)教程之靜態(tài)文件的調(diào)用詳解
這篇文章主要給大家介紹了關(guān)于Django學(xué)習(xí)教程之靜態(tài)文件調(diào)用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用django具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05
Python基于codecs模塊實(shí)現(xiàn)文件讀寫(xiě)案例解析
這篇文章主要介紹了Python基于codecs實(shí)現(xiàn)文件讀寫(xiě)案例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
解決Python 遍歷字典時(shí)刪除元素報(bào)異常的問(wèn)題
下面小編就為大家?guī)?lái)一篇解決Python 遍歷字典時(shí)刪除元素報(bào)異常的問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09
使用pycharm在本地開(kāi)發(fā)并實(shí)時(shí)同步到服務(wù)器
這篇文章主要介紹了使用pycharm在本地開(kāi)發(fā)并實(shí)時(shí)同步到服務(wù)器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08

