Python3使用xlrd、xlwt处理Excel方法数据


Posted in Python onFebruary 28, 2020

说在前头

最近在做毕设,题目是道路拥堵预测系统,学长建议我使用SVM算法进行预测,但是在此之前需要把Excel中的数据进行二次处理,原始数据不满足我的需要,可是。。有346469条数据,不能每一条都自己进行运算并且将它进行归一化运算!!

Python3使用xlrd、xlwt处理Excel方法数据

作为一个Java开发者,Python的使用我是从来没用过的啊,也是作死选了个这么难的题目。。后来在网上查阅发现xlrd可以通过Python代码读取Excel的文件,他的含义是xls文件的read(只读),另外它的同类是xlwt(xls的write喽~),这个是可以执行写入操作的库。那我们就开始:

Python3使用xlrd、xlwt处理Excel方法数据

作为一名新手,Python的dalao千万别喷,我们抱着学习的心态一起来学习这两个库到底怎么使用吧!

一、xlrd的使用

篇幅太多,这篇只介绍xlrd的使用,xlwt下篇继续哦~
想使用肯定先安装,windows系统下如果你安装了Python环境,直接打开cmd键入:$ pip install xlrdxlwt 也是这样安装,说实话Python这些个类库真的是太方便了(题外话)

我们比如要修改这个Excel的数据:

Python3使用xlrd、xlwt处理Excel方法数据

总共有两层:

Python3使用xlrd、xlwt处理Excel方法数据

导入xlrd

import xlrd

读取数据文件

workbook = xlrd.open_workbook(r'E:\test.xlsx')

打印Sheet信息

print(workbook.sheet_names())

打印结果:

Python3使用xlrd、xlwt处理Excel方法数据

根据下标获取表单

print(workbook.sheet_names()[1])

后面加个中括号,里面是表单的位置,我输入1,表示第二页,所以打印:

Python3使用xlrd、xlwt处理Excel方法数据

根据索引或名称获取数据的名称、行或列

index = workbook.sheet_by_index(0)# 根据索引或者行数列数和名称
print('索引名称:'+str(index.name)+' 索引的行数'+
   str(index.nrows)+' 索引的列数'+str(index.ncols))

输出结果:

Python3使用xlrd、xlwt处理Excel方法数据

Python3使用xlrd、xlwt处理Excel方法数据

确实是七行五列,没毛病~

Python3使用xlrd、xlwt处理Excel方法数据

同样根据表单的名称也能拿到Sheet对象

index2 = workbook.sheet_by_name('Sheet1')
print('索引名称:'+str(index2.name)+' 索引的行数'+
   str(index2.nrows)+' 索引的列数'+str(index2.ncols))

输出结果:

Python3使用xlrd、xlwt处理Excel方法数据

获取整行整列的内容

最重要的来了,怎么获取一整行、一整列的内容呢?
首先要拿到表单的对象,通过上面说的两种方法:
我习惯用名称获取:

sheet1= workbook.sheet_by_name('Sheet1')

获取了以后:

row_values = sheet1.row_values(2)
print('第三行的内容:'+str(row_values))
col_values = sheet1.col_values(2)
print('第三列的内容'+str(col_values))

我们看看输出结果:

Python3使用xlrd、xlwt处理Excel方法数据

至于时间为什么是43812.0,这个是天数,可以转换成日期格式,后边我会详细写用法~

Python3使用xlrd、xlwt处理Excel方法数据

百分百没毛病的!~

获取具体几行几列的内容

这个方法有很多,都可以用,看个人习惯,我列举六种:

print(sheet1.cell_value(1, 1))
print(sheet1.cell(1, 1))
print(sheet1.row(1)[1])
print(sheet1.col(1)[1])
print(sheet1.row_values(1)[1])
print(sheet1.col_values(1)[1])

想知道某行某列的类型是什么怎么做呢?

print(sheet1.cell(1, 0).ctype)
print(sheet1.cell(1, 2).ctype)
print(sheet1.cell(1, 3).ctype)

输出结果为:

1
2
3

ctype 分别: 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error

tip: 打印的时候需要注意:

python跟java在类型转换上有很大的不同,这点我更喜欢Java的处理方式(打印的时候通通转换成String类型),比如我想打印很多类型的属性,同时打印没问题,但是Python必须要限定类型为str,否则就会报错

public class test {
  public static void main(String[] args) {
    int num = 1;
    String ss = "sss";
    System.out.println("Integer"+num+"String"+ss);
  }
}

java完全可以正常运行~
Python:

a = 1
b = 'ss'
print('int:'+a+'str'+ b)

拼接的时候必须限定a和b为str类型,否则报错!
报错内容:

Python3使用xlrd、xlwt处理Excel方法数据

如何修改date类型为float类型的数字

想修改时间格式的属性:

as_tuple = xlrd.xldate_as_tuple(sheet1.cell_value(1, 3), workbook.datemode)

cell_value(1,3) 表示我要获取 2019/11/13

Python3使用xlrd、xlwt处理Excel方法数据

第二个参数datemode就不解释了,需要改哪个文件,就调用哪个文件对象的datemode
我们输出一下as_tuple这个对象:

Python3使用xlrd、xlwt处理Excel方法数据

看到这个元组里的数据也可以看出来,前三个分别就是年月日了,所以我们要提取这三个数字:

d = date(*as_tuple[:3])

date()这个方法需要三个参数,分别是年月日,所以我们提取元组的前三个数字正好可以:
我们打印一下:

Python3使用xlrd、xlwt处理Excel方法数据

这个不就是我们需要的格式吗?
等等,我是用斜杠“/”隔开的,这个怎么是“-”,我们改一下格式,通过strftime(string formate time)方法:

strftime = d.strftime('%Y/%m/%d')

打印一下:

Python3使用xlrd、xlwt处理Excel方法数据

这样就完美了~

怎么获取合并单元格

我们转到sheet2

Python3使用xlrd、xlwt处理Excel方法数据

可以看到第六行的2-5列都是合并单元格,内容是无,第七行和第八行的第二列是合并单元格,内容是无,第七行和第八行的第四和第五列是合并单元格,内容是啥都没有。

我们需要用到方法:merged_cells

sheet2 = workbook.sheet_by_name('Sheet2')
print(sheet2.merged_cells)

输出结果:

[(5, 6, 1, 5), (6, 8, 1, 2), (6, 8, 3, 5)]

这个5615,6812,6835啥意思?
四个参数分别为行、行最大(不超过最大行)、列、列最大(不超过最大列)
拿5615举例子,第五行到第六行的左闭右开区间[5,6),这就是第五行,[1,5)表示第一列到第四列,我们看:

Python3使用xlrd、xlwt处理Excel方法数据

由于python是从零开始,所以python的第五行,实际上是Excel的第六行,第1-4列就 是 2-5列,这不就是无吗?这只是告诉你哪些是合并单元格,想打印怎么办?

print(sheet2.cell_value(5, 1))
print(sheet2.cell_value(6, 1))
print(sheet2.cell_value(6, 3))

只去第一个和第三个参数就可以打印出来啦

Python3使用xlrd、xlwt处理Excel方法数据

看到这里说明你真的很努力~看懂为主哦!感谢点赞,有错误请指正,有问题留言告诉我!Bye Bye

Python3使用xlrd、xlwt处理Excel方法数据

到此这篇关于Python3使用xlrd、xlwt处理Excel方法数据的文章就介绍到这了,更多相关Python3使用xlrd、xlwt处理Excel内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
利用python模拟实现POST请求提交图片的方法
Jul 25 Python
python实现决策树、随机森林的简单原理
Mar 26 Python
使用python实现简单五子棋游戏
Jun 18 Python
python多进程并行代码实例
Sep 30 Python
python定义类self用法实例解析
Jan 22 Python
python实现逆滤波与维纳滤波示例
Feb 26 Python
浅谈matplotlib.pyplot与axes的关系
Mar 06 Python
Django实现将一个字典传到前端显示出来
Apr 03 Python
TensorFlow tf.nn.conv2d_transpose是怎样实现反卷积的
Apr 20 Python
python request 模块详细介绍
Nov 10 Python
Python 删除List元素的三种方法remove、pop、del
Nov 16 Python
python爬虫中采集中遇到的问题整理
Nov 27 Python
Python进程Multiprocessing模块原理解析
Feb 28 #Python
python 实现多维数组(array)排序
Feb 28 #Python
python对数组进行排序,并输出排序后对应的索引值方式
Feb 28 #Python
Python使用Socket实现简单聊天程序
Feb 28 #Python
在python3中使用shuffle函数要注意的地方
Feb 28 #Python
Python对称的二叉树多种思路实现方法
Feb 28 #Python
pycharm如何实现跨目录调用文件
Feb 28 #Python
You might like
Yii Framework框架获取分类下面的所有子类方法
2014/06/20 PHP
php使用gearman进行任务分发操作实例详解
2020/02/26 PHP
PHP常用字符串输出方法分析(echo,print,printf及sprintf)
2021/03/09 PHP
jQuery 跨域访问问题解决方法
2009/12/02 Javascript
jquery 经典动画菜单效果代码
2010/01/26 Javascript
javascript 闭包疑问
2010/12/30 Javascript
JS target与currentTarget区别说明
2011/08/28 Javascript
Js参数值中含有单引号或双引号问题的解决方法
2013/11/06 Javascript
JQuery标签页效果的两个实例讲解(4)
2015/09/17 Javascript
谈谈我对JavaScript原型和闭包系列理解(随手笔记8)
2015/12/24 Javascript
探究Javascript模板引擎mustache.js使用方法
2016/01/26 Javascript
jQuery弹出下拉列表插件(实现kindeditor的@功能)
2016/08/16 Javascript
Vue.js组件tab实现选项卡切换
2020/03/23 Javascript
js如何编写简单的ajax方法库
2017/08/02 Javascript
微信小程序解除10个请求并发限制
2018/12/18 Javascript
JS/jQuery实现获取时间的方法及常用类完整示例
2019/03/07 jQuery
Vue 处理表单input单行文本框的实例代码
2019/05/09 Javascript
JavaScript中的惰性载入函数及优势
2020/02/18 Javascript
vue 封装面包屑组件教程
2020/11/16 Javascript
javascript中导出与导入实现模块化管理教程
2020/12/03 Javascript
[59:35]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#1COL VS Alliance第二局
2016/03/04 DOTA
python机器学习之KNN分类算法
2018/08/29 Python
pycham查看程序执行的时间方法
2018/11/29 Python
pytorch-RNN进行回归曲线预测方式
2020/01/14 Python
python实现图像全景拼接
2020/03/27 Python
Nike瑞典官方网站:Nike.com (SE)
2018/11/26 全球购物
在加拿大在线租赁和购买电子游戏:Game Access
2019/09/02 全球购物
戴尔马来西亚官网:Dell Malaysia
2020/05/02 全球购物
经典c++面试题四
2015/05/14 面试题
中式结婚主持词
2014/03/14 职场文书
授权委托书格式模板
2014/04/03 职场文书
励志演讲稿大全
2014/08/21 职场文书
开展党的群众路线教育实践活动总结报告
2014/10/31 职场文书
初中作文评语集锦
2014/12/25 职场文书
PHP 技巧 * SVG 保存为图片(分享图生成)
2021/04/02 PHP
css3带你实现3D转换效果
2022/02/24 HTML / CSS