Python处理Excel常用操作就是读和写,我的需求是需要在原excel文件中进行读写操作。共用到了两个模块xlrd和openpyxl,这两个模块都是需要自己去安装的。openpyxl只能用来处理 Excel 2007 及以上版本的 excel 文件,也就是 .xlsx/.xlsm 格式的表格文件,它对文件大小没有限制;其中xlwt针对Ecxec2007之前的版本,即.xls文件,其要求单个sheet不超过65535

1 写一个包,包的名字叫Util
2 建立一个模块Excel,Excel.py
3 pip install openpyxl==2.4.5
4 类名:ParseExcel
#实现一个构造函数,参数使用excel的绝对路径,并保存到实例变量中
from openpyxl import *
from openpyxl.styles import Border, Side, Font
import time
import datetime class ParseExcel(object):
def __init__(self,excel_file_path):
self.excel_file_path=excel_file_path #加载这个excel文件,并保存到实例变量self.workbook中
class ParseExcel(object):
def __init__(self,excel_file_path):
self.excel_path=excel_file_path
self.workbook=load_workbook(excel_file_path) #实现self.sheet为excel文件的第一个sheet
class ParseExcel(object):
def __init__(self,excel_file_path):
self.excel_path=excel_file_path
self.workbook=load_workbook(excel_file_path)
self.sheet=self.workbook.active # 通过sheet名称获取sheet对象
def get_sheet_by_name(self, sheet_name):
self.sheet=self.workbook.get_sheet_by_name(sheet_name)
return self.sheet # 通过sheet索引获取sheet对象
def get_sheet_by_index(self, sheet_index):
self.sheet=self.workbook.get_sheet_by_index(sheet_index)
return self.sheet # 设置当前要操作的sheet对象,使用index来获取相应的sheet
def set_sheet_by_index(self, sheet_index):
self.sheet=self.workbook.get_sheet_by_index(sheet_index) # 设置当前要操作的sheet对象,使用sheet名称来获取相应的sheet
def set_sheet_by_name(self, sheet_name):
self.sheet=self.workbook.get_sheet_by_name(sheet_name) # 获取默认sheet中最大行数
def get_max_row_no(self):
return self.sheet.max_row # 获取默认 sheet 的最大列数
def get_max_col_no(self):
return self.sheet.max_column # 获取默认sheet的最小(起始)行号
def get_min_row_no(self):
return self.sheet.min_row # 获取默认sheet的最小(起始)列号
def get_min_col_no(self):
return self.sheet.min_column # 获取默认 sheet 的所有行对象,
def get_all_rows(self):
#rows=[]
#for row in self.sheet.iter_rows():
#rows.append(row)
#return rows self.sheet=self.sheet.rows()
return list(self.sheet) # 获取默认sheet中的所有列对象
def get_all_cols(self):
#cols=[]
#for cloumn in self.sheet.iter_cols():
#cols.append(column)
#return cols self.sheet=self.sheet.columns()
return list(self.sheet) # 从默认sheet中获取某一行,第一行从0开始
def get_single_row(self, row_no):
return self.sheet.get_all_rows()[row_no] # 从默认sheet中获取某一列,第一列从0开始
def get_single_col(self, col_no):
return self.sheet.get_all_cols()[col_no] # 从默认sheet中,通过行号和列号获取指定的单元格,注意行号和列号从1开始
def get_cell(self, row_no, col_no):
return self.sheet.cell(row=row_no,column=col_no) # 从默认sheet中,通过行号和列号获取指定的单元格中的内容,注意行号和列号从1开始
def get_cell_content(self, row_no, col_no):
return self.sheet.cell(row=row_no,column=col_no).value # 从默认sheet中,通过行号和列号向指定单元格中写入指定内容,注意行号和列号从1开始
# 调用此方法的时候,excel不要处于打开状态
def write_cell_content(self, row_no, col_no, content, font=None):
self.sheet.cell(row=row_no,column=col_no,value=content,font=None)
self.workbook.save(self.excel_file_path) # 从默认sheet中,通过行号和列号向指定单元格中写入当前日期,注意行号和列号从1开始
# 调用此方法的时候,excel不要处于打开状态
def write_cell_current_time(self, row_no, col_no):
self.sheet.cell(row=row_no,column=col_no,value=time.strftime("%Y:%m:%d",time.localtime()),font=None)
self.workbook.save(self.excel_file_path) def save_excel_file(self):
self.wrokbook.save(self.excel_file_path) if __name__=="__main__":
pe=ParseExcel("c:\\excel.xlsx")
pe.set_sheet_by_index(0)
#print pe.get_default_name()
pe.set_sheet_by_name("Sheet2")
#print pe.get_default_name()
print pe.get_sheet_by_name("Sheet2")
print pe.get_sheet_by_index(0)
print 'max row:', pe.get_max_row_no()
print pe.get_all_rows() # 获取所有行对象
print pe.get_all_rows()[0] # 获取第一行,获取某个行对象
print pe.get_all_rows()[0][1] # 获取第一行,第二列的单元格对象
print pe.get_all_rows()[0][1].value # 获取第一行,第二列单元格对象的值 print pe.get_all_cols() # 获取所有行对象
print pe.get_all_cols()[0] # 获取第一列,获取某个列对象
print pe.get_all_cols()[0][1] # 获取第一列的第二个单元格某个单元格对象
print pe.get_all_cols()[0][1].value # 获取第一列的第二个单元格的值 print pe.get_max_col_no()
print pe.get_min_row_no()
print pe.get_min_col_no()
print pe.get_all_rows()[0]
print len(pe.get_all_rows())
for cell in pe.get_all_rows()[0]:
print cell.value
print pe.get_all_cols()
for col in pe.get_all_cols()[0]:
print col.value
for cell in pe.get_single_row(0):
print cell.value
for col in pe.get_single_col(0):
print col.value
print pe.get_cell(1, 1)
print pe.get_cell_content(1, 1) pe.write_cell_content(4, 2, "wangjing")
print pe.get_cell_content(4, 2)
pe.write_cell_current_time(1, 1)
print pe.get_cell_content(1, 1)

搭建数据驱动框架第一步-实现一个构造函数,将对Excel文件的基本操作API都封装进去的更多相关文章

  1. [Angularjs] 第一步开始一个项目

    [Angularjs] 第一步开始一个项目 一.什么是angularjs angularjs是2009年兴起的,目前由Google维护一个采用mvc模式的js框架,很多时候用来创建单页面应用.我也经常 ...

  2. 零元学Expression Blend 4 - Chapter 3 熟悉操作第一步(制作一个猴子脸)

    原文:零元学Expression Blend 4 - Chapter 3 熟悉操作第一步(制作一个猴子脸) 本篇内容会教你如何使用笔刷.钢笔.渐层以及透明度的调整,还有如何转化图层和路径,最重要的是要 ...

  3. XLConnect:一个用R处理Excel文件的高效平台

    code{white-space: pre;} pre:not([class]) { background-color: white; }if (window.hljs && docu ...

  4. 如何用 php 读取一个很大的 excel 文件。

    这个程序是用php 读取一个很大的excel文件, 先将 excel 文件保存成csv 文件, 然后利用 迭代器 逐行读取 excel 单元格的值, 拿到值以后 做相应处理,并打印结果. <?p ...

  5. (大数据工程师学习路径)第一步 Linux 基础入门----目录结构及文件基本操作

    Linux 目录结构及文件基本操作 介绍 1.Linux 的文件组织目录结构. 2.相对路径和绝对路径. 3.对文件的移动.复制.重命名.编辑等操作. 一.Linux 目录结构 在讲 Linux 目录 ...

  6. springMVC,spring,mybatis全注解搭建框架--第一步,让框架跑起来

    自己从事java开发工作也有一年多了,自己却没有亲手搭建一个完整的框架.于是今天自己动手搭建一个,过程中遇到一些问题,倒腾了大半天终于搞定了. 现在给大家分享一下过程,自己也记录下来,以后学习参考使用 ...

  7. Yii框架第一步-- 安装

    0.首次安装请看 这里 下面的为非首次安装,不需要token的步骤 1.下载composer 官网下载: https://getcomposer.org/download/ 2.开启PHP的opens ...

  8. None.js 第一步 开启一个服务 hello world

    引入 http 模块 var http = require('http'); 创建服务器 http.createServer(function (request, response) { // 发送一 ...

  9. A框架第一步,传递不同参数.主程序执行对应方法

    访问: www.test.com/admin 1============后台目录:admin (确保单一入口) --有入口文件index.php <?phprequire '../A/a.php ...

随机推荐

  1. CEF 右键添加开发者选项菜单项

    在项目开发过程中,有时候需要进行调试测试,然后我们可以在cef上下文菜单中添加自定义开发者工具菜单项,这样会比较方便,最后效果: 实现过程: 让自己的MyClientHandler来继承 CefCon ...

  2. java的一些基本概念——java11、jdk、jre、jvm等

    Java字节码 先介绍下c语言的编译过程,写好代码用编译器(比如gcc)编译过后是机器能够直接执行的二进制机器码. java也类似这种情况,但是java代码文件编译过后不是任何机器都能识别的机器码,而 ...

  3. Python入门 io篇

    简单demo with open('d:/pydemo/pythonStart/fun1.py', 'r') as f: #print(f.read()) while True: line = f.r ...

  4. UVA1328 Period

    思路 KMP算法的next数组是该字符串的最长的相同的前缀和后缀的长度 所以i-next[i]是最小的循环节长度 然后如果next[i]不为0,则证明一定有循环(不一定完整) 然后如果整除,就是完整的 ...

  5. LeetCode in action

    (1) Linked List: 2-add-two-numbers,2.cpp 19-remove-nth-node-from-end-of-list,TBD 21-merge-two-sorted ...

  6. How to fix TFS workspace mapping error in Jenkins

    Once you had update in TFS workspace for Jenkin TFS plugin, you might get error like bellow: [worksp ...

  7. LINQ to Entities 不识别方法“System.String get_Item(Int32)”,因此该方法无法转换为存储表达式。

    1.LINQ to Entities 不识别方法“System.String get_Item(Int32)”,因此该方法无法转换为存储表达式.项目中发现linq to entities 不识别? , ...

  8. zookeeper之 zkServer.sh命令、zkCli.sh命令、四字命令

    一.zkServer.sh 1.查看 zkServer.sh 帮助信息[root@bigdata05 bin]# ./zkServer.sh helpZooKeeper JMX enabled by ...

  9. java jdk动态代理学习记录

    转载自: https://www.jianshu.com/p/3616c70cb37b JDK自带的动态代理主要是指,实现了InvocationHandler接口的类,会继承一个invoke方法,通过 ...

  10. 第 8 章 容器网络 - 071 - 如何定制 Calico 的 IP 池?

    定制IP池 首先定义一个 IP Pool,比如: calicoctl create -f ipPool.yml 用此 IP Pool 创建 calico 网络. docker network crea ...