搭建数据驱动框架第一步-实现一个构造函数,将对Excel文件的基本操作API都封装进去
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都封装进去的更多相关文章
- [Angularjs] 第一步开始一个项目
[Angularjs] 第一步开始一个项目 一.什么是angularjs angularjs是2009年兴起的,目前由Google维护一个采用mvc模式的js框架,很多时候用来创建单页面应用.我也经常 ...
- 零元学Expression Blend 4 - Chapter 3 熟悉操作第一步(制作一个猴子脸)
原文:零元学Expression Blend 4 - Chapter 3 熟悉操作第一步(制作一个猴子脸) 本篇内容会教你如何使用笔刷.钢笔.渐层以及透明度的调整,还有如何转化图层和路径,最重要的是要 ...
- XLConnect:一个用R处理Excel文件的高效平台
code{white-space: pre;} pre:not([class]) { background-color: white; }if (window.hljs && docu ...
- 如何用 php 读取一个很大的 excel 文件。
这个程序是用php 读取一个很大的excel文件, 先将 excel 文件保存成csv 文件, 然后利用 迭代器 逐行读取 excel 单元格的值, 拿到值以后 做相应处理,并打印结果. <?p ...
- (大数据工程师学习路径)第一步 Linux 基础入门----目录结构及文件基本操作
Linux 目录结构及文件基本操作 介绍 1.Linux 的文件组织目录结构. 2.相对路径和绝对路径. 3.对文件的移动.复制.重命名.编辑等操作. 一.Linux 目录结构 在讲 Linux 目录 ...
- springMVC,spring,mybatis全注解搭建框架--第一步,让框架跑起来
自己从事java开发工作也有一年多了,自己却没有亲手搭建一个完整的框架.于是今天自己动手搭建一个,过程中遇到一些问题,倒腾了大半天终于搞定了. 现在给大家分享一下过程,自己也记录下来,以后学习参考使用 ...
- Yii框架第一步-- 安装
0.首次安装请看 这里 下面的为非首次安装,不需要token的步骤 1.下载composer 官网下载: https://getcomposer.org/download/ 2.开启PHP的opens ...
- None.js 第一步 开启一个服务 hello world
引入 http 模块 var http = require('http'); 创建服务器 http.createServer(function (request, response) { // 发送一 ...
- A框架第一步,传递不同参数.主程序执行对应方法
访问: www.test.com/admin 1============后台目录:admin (确保单一入口) --有入口文件index.php <?phprequire '../A/a.php ...
随机推荐
- wm_concat函数oracle 11g返回clob
用wm_concat连接拼接字符串,测试环境是10g,一切正常 到了生产环境是11g,点开直接报错了 wm_concat函数在oracle 10g返回的是字符串,到了11g返回的是clob 解决办法: ...
- sliver
import 'package:flutter/material.dart';import 'package:xxx/bloc/bloc.dart';import 'package:xxx/model ...
- centos linux查看硬盘型号
[root@]# smartctl --all /dev/sdasmartctl 6.5 2016-05-07 r4318 [x86_64-linux-3.10.0-957.1.3.el7.x86_6 ...
- Learning-MySQL【3】:数据类型和运算符
一.数据类型 1.数值类型 为每张表的每个字段选择合适的数据类型是数据库设计过程中一个重要的步骤. 数字分为整数和小数.其中整数用整数类型表示,小数用浮点数类型和定点数类型表示. 浮点数类型包括单精度 ...
- JavaScript(数组、Date、正则)
数组 创建数组 // 一.自变量创建数组 // 1-通过字面量创建一个空数组 var arr1 = []; console.log(arr1) console.log(typeof arr1); // ...
- nmon 性能监控网页结果显示——EasyNmon
首先,看看最终展示的结果显示样式: 报告界面: 1.安装包下载地址:https://github.com/mzky/easyNmon 2.下载后有2个压缩文件: 其中,nmon16g_x86中含有不同 ...
- 测试是否支持辨别tex公式
1.首先启动博客园公式编写支持(latex) 2.编写公式 3.结果 $a+b=5$ $c+d=7$
- 第八届蓝桥杯省赛 K倍区间
问题描述 给定一个长度为N的数列,A1, A2, ... AN,如果其中一段连续的子序列Ai, Ai+1, ... Aj(i <= j)之和是K的倍数,我们就称这个区间[i, j]是K倍区间. ...
- 当后台获取内容有标签时如何过滤---angular
$sce controller中注入$sce服务; 假设将获取到的标签内容为result; $scope.result = $sce.trustAsHtml(result); 在html页面中则< ...
- Win10系统截屏快捷键
截全屏 win+prt scsysrq 图片位置:C:\Users\ASUS\Pictures\Screenshots 此电脑/图片/屏幕截图 截当前活动窗口 alt+prt scsysrq ...