python中通过xlwt、xlrd和xlutils操作xls
- xlwt模块用于在内存中生成一个xls/xlsx对象,增加表格数据,并把内存中的xls对象保存为本地磁盘xls文件;
- xlrd模块用于把本地xls文件加载到内存中,可以读取xls文件的表格数据,查询xls文件的相关信息;
- xlwt可以生成xls文件,xlrd可以读取已经存在的xls文件,但是如果要修改本地已经存在的xls文件,就需要用到xlutils模块。
- xlutils模块是xlrd和xlwt之间的桥梁,可以使用xlutils模块中的copy模块,拷贝一份通过xlrd读取到内存中的xls对象,就可以在拷贝对象上像xlwt中那样修改xls表格的内容,并保存到本地。
xlutils模块安装
xlutils安装包下载链接: https://pypi.python.org/pypi/xlutils
或 http://download.csdn.net/download/dcrmg/10040953
目前最新版本是2.0 ++ 名称是 "xlutils-2.0.0-py2.py3-none-any.whl"
安装指令: pip install
xlutils-2.0.0-py2.py3-none-any.whl
下边这个示例使用xlwt生成一个xls文件,使用xlrd读取xls文件内容,使用xlutils修改本地xls文件内容:
import xlwt
import xlrd
import xlutils.copy
if __name__ == '__main__':
workbook = xlwt.Workbook() #使用xlwt新生成一个workbook
sheet = workbook.add_sheet("sheet1") #增加一个名称为sheet1的sheet
sheet2 = workbook.add_sheet("sheet2")
row0 = ['Order', 'Name', 'Class', 'Socer', 'Num'] #第一行内容
row1 = [u'1', u'Tom', u'4', u'87', u'B']
row2 = [u'2', u'Mars', u'4', u'91', u'A']
for i in range(len(row0)):
sheet.write(0, i, row0[i]) #write(行,列,值)
sheet.write(1, i, row1[i])
sheet.write(2, i, row2[i])
workbook.save('/home/xxx/xx.xls') #保存workbook为xls格式
workbook = xlrd.open_workbook('/home/dcrmg/work/1025.xls') #使用xlrd打开本地的workbook
num_sheet = workbook.nsheets #workbook内总的sheet数量
names_sheet = workbook.sheet_names() #workbook中所有sheet名称的列表
sheet1 = workbook.sheet_by_index(0) #根据序号获取sheet
sheet2 = workbook.sheet_by_index(1)
sheet = workbook.sheet_by_name(u'sheet1') #根据sheet名称获取sheet
sheet_name = sheet1.name #sheet名称
sheet_rows = sheet1.nrows #sheet总的行数
sheet_clos = sheet1.ncols #sheet总的列数
val2 = sheet1.row_values(2) #第n+1行内容的列表
print val2
val3 = sheet1.col_values(0) #第n+1列内容的列表
value = sheet1.row(1)[0].value.encode('utf-8') #row(rows)(cols) 第rows+1行第cols+1列所在表格的内容
print value
value = sheet1.col(1)[0].value.encode('utf-8') #col(cols)(rows) 第cols+1列第rows+1行所在表格的内容
print value
workbook_xlutils = xlutils.copy.copy(workbook) #使用xlrd打开一个已存在的xls,并通过xlutils复制
sheet1_xlutils = workbook_xlutils.get_sheet(0) #通过sheet序号获取sheet
row3 = [u'3', u'Kim', u'4', u'100', u'A+']
row4 = [u'4', u'Klus', u'4', u'98', u'A+']
for i in range(len(row3)): #写入sheet_xlutils的修改值
sheet1_xlutils.write(3, i, row3[i])
sheet1_xlutils.write(4, i, row4[i])
sheet1_xlutils.write(5, 10, 99)
workbook_xlutils.save('/home/xxx/xx.xls') #保存xls
python中通过xlwt、xlrd和xlutils操作xls的更多相关文章
- Python中对 文件 的各种骚操作
Python中对 文件 的各种骚操作 python中对文件.文件夹(文件操作函数)的操作需要涉及到os模块和shutil模块. 得到当前工作目录,即当前Python脚本工作的目录路径: os.getc ...
- Python中实现对list做减法操作介绍
Python中实现对list做减法操作介绍 这篇文章主要介绍了Python中实现对list做减法操作介绍,需要的朋友可以参考下 问题描述:假设我有这样两个list, 一个是list1,list1 = ...
- Python模块学习之xlrd、xlutils、openpyxl 读写/追加Excel文件
Python操作Excel的四个工具包 xlrd: 对Excel进行读相关操作,注意只能操作 .xls xlwt: 对Excel进行写相关操作,注意只能操作 .xls,且只能创建一个全新的Excel然 ...
- python中的字符串(str)操作
字符串是python中数据类型.一般就单引号(‘’)或双引号(“”)引起来的内容就是字符串. 例如:下面两个都是定义字符串 str1 = "hello world" str2 = ...
- Python中对字节流/二进制流的操作:struct
前言 前段时间使用Python解析IDX文件格式的MNIST数据集,需要对二进制文件进行读取操作,其中我使用的是struct模块.查了网上挺多教程都写的挺好的,不过对新手不是很友好,所以我重新整理了一 ...
- python 中几种基本的矩阵操作应用
在图像处理中,python 的矩阵运算经常会用到一些简单的操作,可是,由于好久没用,很多东西还是忘记了,这里做个备忘: #-*-coding:utf-8-*- import numpy as np a ...
- python中文件的读和写操作
一.打开文件 data = open("yesterday",encoding="utf-8").read() # python默认的打字符编码是unicode ...
- python中几个实用的文件操作
1. 判断指定目录是否存在: os.path.exists(input_folder) 2. 判断指定目录是不是文件夹 os.path.isdir(input_folder) 3. 判断指定目录是不是 ...
- python中scipy学习——随机稀疏矩阵及操作
1.生成随机稀疏矩阵: scipy中生成随机稀疏矩阵的函数如下: scipy.sparse.rand(m,n,density,format,dtype,random_state) 1 参数介绍: 参数 ...
随机推荐
- CheckedListBoxControl 或CheckedListBox 控件中显示水平滚动条 z
public partial class Form1 : Form { public Form1() { InitializeComponent(); DisplayHScroll(); } /// ...
- ssh登录时不校验被登录机器的方法
在linux的用户目录下的.ssh文件下,touch config:注意config的权限控制,-rw-r--r--. 配置内容: cat config: Host * StrictHostKeyCh ...
- .Net ToString Format [转]
源文 :http://blog.csdn.net/luyifeiniu/article/category/25663/2 stringstr1 =string.Format("{0:N1}& ...
- 关于JavaScript禁止点击事件
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Allegro16.6和17.0和17.2中将板框导出DXF文件
Allegro16.6和17.0和17.2中将板框导出DXF文件 转载 https://blog.csdn.net/pieces_thinking/article/details/69817600 标 ...
- centos创建本地yum仓库
怎样发布自己软件的安装和更新YUM源 在创建之前,我们先了解些相关的内容: yum仓库可以支持三种途径提供给yum在安装的时候下载rpm包 第一种: ftp服务 ftp:// 第二种: http ...
- kubernetes安装过程中遇到问题及解决
系列目录 根据机器环境的不同,有的可能一次就安装成功,有的则可能遇到各种各样的坑需要排查.建议不熟悉linux的用户使用全新的环境来安装kubernetes.以下记录本人在安装过程中遇到的问题及解决方 ...
- nodejs websocket 聊天应用
前端一直是一块充满惊喜的土地,不仅是那些富有创造性的页面,还有那些惊赞的效果及不断推出的新技术.像node.js这样的后端开拓者直接将前端人员的能力扩大到了后端.瞬间就有了一统天下的感觉,来往穿梭于前 ...
- React项目结构
任何一种语言.框架,在真正上手的时候,多多少少会想想怎么安排项目结构(正所谓磨刀不误砍柴工),React也不例外. google了下,拿下面3篇博客来说道说道. (1) how-to-better-o ...
- Linux快捷键和vim快捷键
系统下常用快捷键 ctrl+左右键 在单词之间跳转 Ctrl + a 光标移动到行首(ahead of line),相当于通常的Home键 Ctrl + e ...