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


Posted in Python onJune 14, 2018

最近刚开始学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') #保存

以上这篇利用python对Excel中的特定数据提取并写入新表的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python和pyqt实现360的CLable控件
Feb 21 Python
使用Python编写vim插件的简单示例
Apr 17 Python
Python中的is和==比较两个对象的两种方法
Sep 06 Python
python3实现windows下同名进程监控
Jun 21 Python
django rest framework 数据的查找、过滤、排序的示例
Jun 25 Python
PyQt5 QTableView设置某一列不可编辑的方法
Jun 25 Python
使用pip安装python库的多种方式
Jul 31 Python
解决django-xadmin列表页filter关联对象搜索问题
Nov 15 Python
Python3开发实例之非关系型图数据库Neo4j安装方法及Python3连接操作Neo4j方法实例
Mar 18 Python
如何理解python中数字列表
May 29 Python
如何从csv文件构建Tensorflow的数据集
Sep 21 Python
如何在pycharm中安装第三方包
Oct 27 Python
Python基于最小二乘法实现曲线拟合示例
Jun 14 #Python
详解python之协程gevent模块
Jun 14 #Python
python 筛选数据集中列中value长度大于20的数据集方法
Jun 14 #Python
浅谈Tensorflow由于版本问题出现的几种错误及解决方法
Jun 13 #Python
tensorflow: 查看 tensor详细数值方法
Jun 13 #Python
终端命令查看TensorFlow版本号及路径的方法
Jun 13 #Python
解决Tensorflow使用pip安装后没有model目录的问题
Jun 13 #Python
You might like
php重定向的三种方法分享
2012/02/22 PHP
学习php设计模式 php实现策略模式(strategy)
2015/12/07 PHP
CI框架(CodeIgniter)实现的数据库增删改查操作总结
2018/05/23 PHP
详解PHP的抽象类和抽象方法以及接口总结
2019/03/15 PHP
JavaScript脚本语言在网页中的简单应用
2007/05/13 Javascript
Jquery升级新版本后选择器的语法问题
2010/06/02 Javascript
UpdatePanel和Jquery冲突的解决方法
2013/04/01 Javascript
jquery触发a标签跳转事件示例代码
2013/07/21 Javascript
浅析javascript操作 cookie对象
2014/12/26 Javascript
javascript实现确定和取消提示框效果
2015/07/10 Javascript
jQuery的内容过滤选择器学习教程
2016/04/18 Javascript
浅谈regExp的test方法取得的值变化的原因及处理方法
2017/03/01 Javascript
input输入框内容实时监测(附代码)
2017/08/15 Javascript
探索webpack模块及webpack3新特性
2017/09/18 Javascript
node全局变量__dirname与__filename的区别
2019/01/14 Javascript
JavaScript类型相关的常用操作总结
2019/02/14 Javascript
vue-i18n结合Element-ui的配置方法
2019/05/20 Javascript
vux-scroller实现移动端上拉加载功能过程解析
2019/10/08 Javascript
Ajax获取node服务器数据的完整步骤
2020/09/20 Javascript
Python输出9*9乘法表的方法
2015/05/25 Python
使用python telnetlib批量备份交换机配置的方法
2019/07/25 Python
python3实现弹弹球小游戏
2019/11/25 Python
Windows下Anaconda安装、换源与更新的方法
2020/04/17 Python
Python爬虫requests库多种用法实例
2020/05/28 Python
python中取绝对值简单方法总结
2020/07/24 Python
发现两个有趣的CSS3动画效果
2013/08/14 HTML / CSS
印度首选时尚目的地:Reliance Trends
2018/01/17 全球购物
ProBikeKit德国:在线公路自行车专家
2018/06/03 全球购物
惠普香港官方商店:HP香港
2019/04/30 全球购物
大学生未来职业生涯规划书
2014/02/15 职场文书
优秀教师个人总结
2015/02/11 职场文书
财务部岗位职责范本
2015/04/14 职场文书
公司辞职信模板
2015/05/13 职场文书
vue项目两种方式实现竖向表格的思路分析
2021/04/28 Vue.js
详解Laravel框架的依赖注入功能
2021/05/27 PHP
MySQL事务操作的四大特性以及并发事务问题
2022/04/12 MySQL