python openpyxl 2.5.4 版本 excel常用操作封装

最近搭框架用的openpyxl 2.5.4版本,之前封装的函数有些提示不推荐使用了,我做了一些更新:

代码:

# encoding=utf-8

from openpyxl import load_workbook
from openpyxl.styles import Border, Side, Font
import time

class parseExcel(object):
    def __init__(self, excelPath):
        self.excelPath = excelPath
        self.workbook = load_workbook(excelPath)  # 加载excel
        self.sheet = self.workbook.active  # 获取第一个sheet
        self.font = Font(color=None)
        self.colorDict = {"red": ‘FFFF3030‘, "green": ‘FF008B00‘}

# 设置当前要操作的sheet对象,使用index来获取相应的sheet
    def get_sheet_by_index(self, sheet_index):
        sheet_name = self.workbook.sheetnames[sheet_index]
        self.sheet = self.get_sheet_by_name(sheet_name)
        return self.sheet

# 获取当前默认sheet的名字
    def get_default_sheet(self):
        return self.sheet.title

# 设置当前要操作的sheet对象,使用sheet名称来获取相应的sheet
    def get_sheet_by_name(self, sheet_name):
        self.sheet = self.workbook[sheet_name]
        return self.sheet

# 获取默认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):
        return list(self.sheet.iter_rows())
        # return list(self.rows)也可以

# 获取默认sheet中的所有列对象
    def get_all_cols(self):
        return list(self.sheet.iter_cols())
        # return list(self.sheet.columns)也可以

# 从默认sheet中获取某一列,第一列从0开始
    def get_single_col(self, col_no):
        return self.get_all_cols()[col_no]

# 从默认sheet中获取某一行,第一行从0开始
    def get_single_row(self, row_no):
        return self.get_all_rows()[row_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
        self.workbook.save(self.excelPath)
        return self.sheet.cell(row=row_no, column=col_no).value

# 从默认sheet中,通过行号和列号向指定单元格中写入当前日期,注意行号和列号从1开始
    # 调用此方法的时候,excel不要处于打开状态
    def write_cell_current_time(self, row_no, col_no):
        time1 = time.strftime("%Y-%m-%d %H:%M:%S")
        self.sheet.cell(row=row_no, column=col_no).value = str(time1)
        self.workbook.save(self.excelPath)
        return self.sheet.cell(row=row_no, column=col_no).value

def save_excel_file(self):
        self.workbook.save(self.excelPath)

if __name__ == ‘__main__‘:
    p = parseExcel(u‘D:\\testdata.xlsx‘)
    print u"获取默认行:", p.get_default_sheet()

print u"设置sheet索引为1", p.get_sheet_by_index(1)
    print u"获取默认sheet:", p.get_default_sheet()
    print u"设置sheet索引为0", p.get_sheet_by_index(0)
    print u"获取默认sheet:", p.get_default_sheet()
    print u"最大行数:", p.get_max_row_no()
    print u"最大列数:", p.get_max_col_no()
    print u"最小起始行数:", p.get_min_row_no()
    print u"最小起始列数:", p.get_min_col_no()
    print u"所有行对象:", p.get_all_rows()
    print u"所有列对象:", p.get_all_cols()
    print u"获取某一列(2):", p.get_single_col(2)
    print u"获取某一行(4):", p.get_single_row(4)
    print u"取得行号和列号(2,2)单元格:", p.get_cell(2, 2)
    print u"取得行号和列号单元格的内容(2,2)", p.get_cell_content(2, 2)
    print u"行号和列号写入内容(11,11):‘xiaxiaoxu‘", p.write_cell_content(11, 11, ‘xiaxiaoxu‘)
    print u"行号和列号写入当前日期(13,13):", p.write_cell_current_time(13, 13)

结果:ok

原文地址:https://www.cnblogs.com/xiaxiaoxu/p/9350298.html

时间: 2024-10-16 11:38:48

python openpyxl 2.5.4 版本 excel常用操作封装的相关文章

java导入导出excel常用操作小结及简单示例

POI中常用设置EXCEL的操作小结: 操作excel如下 HSSFWorkbook wb = new HSSFWorkbook();  //创建一个webbook,对应一个Excel文件 HSSFSheet sheet = wb.createSheet();    //添加一个sheet,对应Excel文件中的sheet 构造方法可以有参也可以无参wb.createSheet("学生表一") HSSFRow row = sheet.createRow((int) 0);  //she

python 2.6.6升级版本的详细操作步骤!

python2.6.6升级2.7.x 1.下载python2.7.x wget https://www.python.org/ftp/python/2.7.x/Python-2.7.x.tgz 2.解压并编译安装 tar -zxvf Python-2.7.x.tgz && cd Python-2.7.x && ./configure && make all && make install && make clean  &

Python元组类型、字典类型及常用操作

一.元组类型 1.用途 记录多个值,当多个值没有改的需求,此时用元组更合适,Python的元组与列表类似,不同之处在于元组的元素不能修改. 2.定义方式 在()内用逗号分隔开多个任意类型的值 t=(1,6,(5,''),{}) #t=tuple((1,6,(5,''),{})) t1=tuple('hello') 3.常用操作+内置的方法 优先掌握的操作:1.按索引取值(正向取+反向取):只能取 t=(1,6,(5,''),[1,5,3]) t[0]='1' 2.切片(顾头不顾尾,步长) t=(

Python语法速查: 4. 字符串常用操作

(1)字符串常用方法 Python3中,字符串全都用Unicode形式,所以省去了很多以前各种转换与声明的麻烦.字符串属于序列,所有序列可用的方法(比如切片等)都可用于字符串. 注意:字符串属于不可变序列,所有处理修改字符的方法,都会生成一个新字符串返回,原字符串不会变. 字符串方法 简述 举例或说明 字符串内容检查 s.isalpha() 是否所有字符都为字母 'abc'.isalpha()   # 结果为 True s.islower() 字符串中字母是否都为小写(无视其中的非字母字符) '

Python 元组和集合的特点及常用操作

一.元组的特点: 1.有序的集合 2.通过偏移来取数据 3.属于不可变的对象,不能在原地修改内容,没有排序,修改等操作. tuple支持的方法很少 >>> dir(tuple) ['__add__', '__class__', '__contains__', '__delattr__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__

poi 操作excel 常用操作

之前写过一篇类似的文章 这次重新写一下 添加了一些关于样式的代码 package excel; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.lang.reflect.Method; import java.util.

Excel常用操作,求和等

今天用Excel写了一个加班统计表格,在统计加班时长时,竟然不会使用Excel自动求和,看来拳不离手曲不离口,一个工具一段时间不用,就可能生疏.现在记录在这里,做个备忘. 求和很简单,使用"=SUM(D2:D18)"类似的函数即可,见图:

Excel常用操作

从左边开始取 =MID(TRIM(G2),1,5) 设置字符长度,不足补零 =text(C2,"000000") 从右边开始取 =trim(right(trim(E2),4)) 去括号 =TRIM(J2) 匹配字符 =VLOOKUP(C2,aaa,4,0) 来自为知笔记(Wiz)

poi excel 常用操作 [冻结、合并、链接]

基本 Workbook wb= new HSSFWorkbook(); Sheet sheet = wb.createSheet("sheetName"); Row row = sheet.createRow(0); //第一行 Cell cell = row.createCell(0);//第一个单元格 cell.setCellValue("企业名称");//单元格赋值 cell.setCellStyle(cellStyle);//设置样式 FileOutputS