利用python对Excel中的特定数据提取并写入新表的方法

作者:heavenmark 时间:2023-09-17 16:03:10 

最近刚开始学python,正好实习工作中遇到对excel中的数据进行处理的问题,就想到利用python来解决,也恰好练手。

实际的问题是要从excel表中提取日期、邮件地址和时间,然后统计在一定时间段内某个人在某个项目上用了多少时间,最后做成一张数据透视表(这是问题的大致意思)。

首先要做的就是数据提取了,excel中本身有一个text to column的功能,但是对列中规律性不好的数据处理效果很差,不能分割出想要的数据,所以我果断选择用python来完成。

要用的库一个是对excel读写处理的,一个事正则表达式的库。

因为xlwt和xlrd只能对03版以前的excel处理,所以我选择了openpyxl。

以下代码就是自己敲的,写了对日期和邮件地址的提取,最后出来效果不错,仅供大家参考,欢迎交流与改进。


import openpyxl
import re

def Exceldivide(file_dir):
wb=openpyxl.load_workbook(file_dir)   #打开原有的excel表
sheet=wb.get_sheet_by_name('Sheet1')
tuple(sheet['A1':'C3'])

wb.create_sheet('Sheet2')     #新建一个表
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']:   #提取日期和邮件数据
 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']:   #把日期数据写入新表
for cell in rows:
 cell.value=a
 print(cell.coordinate,cell.value)
for rows in sheet2['B1':'B9']:  #把邮件数据写入新表  
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') #保存

来源:https://blog.csdn.net/heavenmark/article/details/73518853

标签:python,Excel,提取
0
投稿

猜你喜欢

  • JavaScript插件化开发教程 (一)

    2024-04-26 17:13:07
  • oracle下加密存储过程的方法

    2009-02-28 10:50:00
  • 用gpu训练好的神经网络,用tensorflow-cpu跑出错的原因及解决方案

    2021-02-11 08:06:31
  • python 实现rolling和apply函数的向下取值操作

    2022-03-15 07:10:08
  • Python对象与引用的介绍

    2023-04-30 12:51:59
  • 七种Python代码审查工具推荐

    2021-06-16 07:07:34
  • 浅谈python锁与死锁问题

    2022-06-02 16:38:37
  • C#动态创建Access数据库及密码的方法

    2024-01-17 21:37:21
  • Navicat for MySQL 与 MySQL-Front比较

    2009-02-12 17:33:00
  • Numpy中扁平化函数ravel()和flatten()的区别详解

    2022-09-23 08:52:23
  • pandas值替换方法

    2021-05-31 20:22:38
  • 树莓派中python获取GY-85九轴模块信息示例

    2021-01-21 18:48:15
  • 浅谈pytorch、cuda、python的版本对齐问题

    2022-12-03 13:04:54
  • Git配置别名简化操作命令方式详解

    2022-03-20 03:34:12
  • python开发一个解析protobuf文件的简单编译器

    2021-08-11 12:01:22
  • python 实现的截屏工具

    2023-05-15 00:20:39
  • 浅说相册图片详情页面中大图的浏览方式

    2009-02-01 18:34:00
  • 在VS2017中用C#调用python脚本的实现

    2021-09-19 00:59:06
  • msxml3.dll 错误 '800c0005'终极解决办法

    2009-10-05 18:40:00
  • SQL语句练习实例之三——平均销售等待时间

    2011-10-24 20:11:47
  • asp之家 网络编程 m.aspxhome.com