Python中xlrd、xlwt、win32com模块对xls文件的读写操作
# -*- coding: utf-8 -*-
#xlrd和xlwt只支持xls文件读写,openpyxl只支持xlsx文件的读写操作
import xlrd
import xlwt
import win32com
from win32com.client import constants,Dispatch
from openpyxl import load_workbook
from openpyxl import Workbook
from openpyxl.writer.excel import ExcelWriter
#--------------------------------使用win32com模块批量读入要处理的log文件--------------#
#注意表的计数是从1开始的和openpyxl类似
def win32ReadExcel(inputFile,num):
#存放数据字典
data_dic = {}
line = 0
for i in range(1,num+1):
readfile = inputFile + str(i) + '.xls'
print (readfile)
xlApp = win32com.client.Dispatch('Excel.Application')
wb = xlApp.Workbooks.Open(readfile)
#取第一张表
ws = wb.Worksheets(1)
info = ws.UsedRange
rows = info.Rows.Count
print (rows)
# 建立存储数据的字典
# t = ws.Cells(1, 1).Value
# print (t)
for rx in range(0,rows-1):
temp_list = []
w1 = ws.Cells(rx+2, 1).Value
w2 = ws.Cells(rx+2, 2).Value
w3 = ws.Cells(rx+2, 3).Value
w4 = ws.Cells(rx+2, 4).Value
w5 = ws.Cells(rx+2, 5).Value
temp_list = [w1,w2,w3,w4,w5]
data_dic[line] = temp_list
line = line + 1
# for i in range(rows):
# data_dic[line] = ws.Rows[i+1].Cells
# line = line + 1
print (data_dic)
return data_dic
#------------------------------使用xlrd模块批量读入要处理的log文件--------------#
def readExcel(inputFile,num):
#存放数据字典
data_dic = {}
line = 0
for i in range(1,num+1):
readfile = inputFile + str(i) + '.xls'
print (readfile)
wb = xlrd.open_workbook(readfile)
#取第一张表
ws = wb.sheets()[0]
rows = ws.nrows
print (rows)
# 建立存储数据的字典
for rx in range(0,rows-1):
# print (rx)
data_dic[line] = ws.row_values(rx+1)
line = line + 1
return data_dic
#-------------------------生成的xls格式的错误日志信息---------------------#
#注意xls格式的表示从0开始计数的
def exportXlsExcel(outputFile,data_log):
file = xlwt.Workbook(encoding='utf-8',style_compression=0)
table = file.add_sheet('sheet1',cell_overwrite_ok=True)
table.write(0,0,'1')
table.write(0,1,'2')
table.write(0,2,'3')
table.write(0,3,'4')
table.write(0,4,'5')
#读取过滤后的日志信息并写入xls文件中
for i in range(0,len(data_log)):
for j in range(0,5):
table.write(i+1,j,data_log[i][j])
file.save(outputFile);
#---------------------------------程序入口---------------------------------#
if __name__ == '__main__':
data_dic = {}
data_dic = win32ReadExcel('H:\Practice\j730_5_',3)
#data_log = dealLog(data_dic)
#exportXlsxExcel('bbbb3.xlsx',data_log)
exportXlsExcel('bbbb.xls',data_log)
from: https://blog.csdn.net/revitalizing/article/details/47423427
Python中xlrd、xlwt、win32com模块对xls文件的读写操作的更多相关文章
- Python中xlrd和xlwt模块使用方法 (python对excel文件的操作)
本文主要介绍可操作excel文件的xlrd.xlwt模块.其中xlrd模块实现对excel文件内容读取,xlwt模块实现对excel文件的写入. 安装xlrd和xlwt模块 xlrd和xlwt模块不是 ...
- python中常⽤的excel模块库
python中常用的excel模块库&安装方法 openpyxl openpyxl是⼀个Python库,用于读取/写⼊Excel 2010 xlsx / xlsm / xltx / xltm⽂ ...
- Python中os和shutil模块实用方法集…
Python中os和shutil模块实用方法集锦 类型:转载 时间:2014-05-13 这篇文章主要介绍了Python中os和shutil模块实用方法集锦,需要的朋友可以参考下 复制代码代码如下: ...
- Python中os和shutil模块实用方法集锦
Python中os和shutil模块实用方法集锦 类型:转载 时间:2014-05-13 这篇文章主要介绍了Python中os和shutil模块实用方法集锦,需要的朋友可以参考下 复制代码代码如下: ...
- python中根据字符串导入模块module
python中根据字符串导入模块module 需要导入importlib,使用其中的import_module方法 import importlib modname = 'datetime' date ...
- python中的第三方日志模块logging
基本上每个系统都有自己的日志系统,可以使自己写的,也可以是第三方的.下面来简单介绍一下python中第三方的日志模块,入手还是比较简单的,但是也很容易给自己埋雷. 下面是我参考的资料链接 入手demo ...
- python中time、datetime模块的使用
目录 python中time.datetime模块的使用 1.前言 2.time模块 1.时间格式转换图 2.常用方法 3.datetime模块 python中time.datetime模块的使用 1 ...
- python中的logging日志模块
日志是程序不可或缺的一部分.它可以记录程序的运行情况,帮助我们更便捷地发现问题,而python中的logging日志模块给我们提供了这个机会. logging给我们提供了五种函数用来输出日志:debu ...
- Python中好用的模块们
目录 Python中好用的模块们 datetime模块 subprocess模块 matplotlib折线图 importlib模块 Python中好用的模块们 datetime模块 相信我们都使 ...
随机推荐
- leetcode.排序.451根据字符出现频率排序-Java
1. 具体题目 给定一个字符串,请将字符串里的字符按照出现的频率降序排列. 示例 1: 输入: "tree" 输出: "eert" 解释: 'e'出现两次,'r ...
- matplotlib系列——折线图
import numpy as np import matplotlib.pyplot as plt import matplotlib #数据准备 #numpy.linspace(start, st ...
- js的this、bind、call、apply个人领悟
this 1.非箭头函数: 如果是该函数是一个构造函数,this指针指向一个新的对象 在严格模式下的函数调用下,this指向undefined 如果是该函数是一个对象的方法,则它的this指针指向这个 ...
- P3391 文艺平衡树(Splay)
题目背景 这是一道经典的Splay模板题--文艺平衡树. 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1, ...
- ps学习记录
基本快捷键: ctrl + 放大 ctrl - 缩小 ctrl 空格键 放大工具 ctrl 0 适合屏幕大小 ctrl 1 显示实际大小 ctrl n 新建画布 ctrl v 移动工具 按住alt键 ...
- react学习笔记_03-组件&props
组件 & Props的学习 组件允许你将 UI 拆分为独立可复用的代码片段,并对每个片段进行独立构思. 组件,从概念上类似于 JavaScript 函数.它接受任意的入参(即 “props”) ...
- 使用extract-text-webpack-plugin处理css文件路径问题
首先看到我们的文件夹目录如下: webpack.config.js //解析分离cssconst ExtractTextPlugin = require('extract-text-webpack-p ...
- Linux安装篇超详细
在此篇文章中主要介绍Linux系统的安装,以及学习大数据过程中Linux中常用的命令有哪些. 一.Linux(CentOs6.8)的安装 1.安装VMware虚拟机 虚拟机下载地址:https://p ...
- Oracle varchar2或char类型的byte和char的区别
那其中的BYTE和CHAR有什么区别呢 BYTE,用字节指定:VARCHAR2(10 BYTE).这能支持最多10字节的数据,在一个多字节字符集中,这可能只是两个字符.采用多字节字符集时,字节与字符并 ...
- Codeforces 360D Levko and Sets (数论好题)
题意:有一个长度为n的数组a和一个长度为m的数组b,一个素数p.有n个集合,初始都只有一个1.现在,对(i从1到n)第i个集合执行以下操作: 对所有集合中的元素c,把c * (a[i] ^ b[j]) ...