安装

pip install xlrd
pip install xlwt
pip install xlutils

 

导入

import xlrd
import xlwt
import xlutils

 

读取excel

# ----读取excel----
data= xlrd.open_workbook(excel_file)

 

读取sheet

# ----读取sheet----
# 通过索引顺序获取sheet 
table = data.sheets()[0]

# 通过索引顺序获取sheet 
table = data.sheet_by_index(0))

# 通过名称获取sheet 
table = data.sheet_by_name("sheet")

# 返回book中所有sheet的名字
names = data.sheet_names()

# 传入索引或sheet名检查某个sheet是否导入完毕
table.sheet_loaded("sheet")
table.sheet_loaded(0)

# sheet名
table.name

# sheet列数
table.ncols

# sheet行数
table.nrows

 

读取sheet的行

# 返回由rowx行中所有的单元格对象组成的列表
table.row(rowx)

# 获取rowx行第一个单元格的类型
# 0. empty(空的),1 string(text), 2 number, 3 date, 4 boolean, 5 error, 6 blank(空白表格)
table.row(rowx)[0].ctype

# 获取rowx行第一个单元格的值
table.row(rowx)[0].value

# 返回由rowx行中所有的单元格对象组成的列表
table.row_slice(self, rowx, start_colx=0, end_colx=None)

# 返回由rowx行中所有单元格的数据类型组成的列表
table.row_types(rowx, start_colx=0, end_colx=None)

# 返回由rowx行中所有单元格的数据组成的列表
table.row_values(rowx, start_colx=0, end_colx=None)

# 返回rowx行的有效单元格长度
table.row_len(rowx)

 

读取sheet的列

#返回colx列中所有的单元格对象组成的列表
table.col(colx, start_rowx=0, end_rowx=None)  

#返回colx列中所有的单元格对象组成的列表
table.col_slice(colx, start_rowx=0, end_rowx=None)  

#返回colx列中所有单元格的数据类型组成的列表
table.col_types(colx, start_rowx=0, end_rowx=None) 
   
#返回colx列中所有单元格的数据组成的列表
table.col_values(colx, start_rowx=0, end_rowx=None)

 

读取sheet的单元格

# 返回单元格对象
cell = table.cell(rowx,colx)
# 单元格数据类型
# 0. empty(空的),1 string(text), 2 number, 3 date, 4 boolean, 5 error, 6 blank(空白表格)
cell.ctype
# 单元格值
cell.value
# 返回单元格中的数据类型
table.cell_type(rowx,colx)
# 返回单元格中的数据
table.cell_value(rowx,colx)
# 暂时还没有搞懂
table.cell_xf_index(rowx, colx)

 

写入excel

# 使用xlutils将xlrd读取的对象转为xlwt可操作对象,table即上述xlrd读取的table
workbook = xlutils.copy(table)

# 或者如果你只是想创建一张空表
workbook = xlwt.Workbook(encoding = 'utf-8')

# 创建一个sheet
worksheet = workbook.add_sheet('sheet')
# 获取一个已存在的sheet
worksheet = workbook.get_sheet('sheet')

# 写入一个值,括号内分别为行数、列数、内容
worksheet.write(row, column, "memeda")

workbook.save('memeda.xls')

 

带样式写入示例

workbook = xlwt.Workbook(encoding = 'utf-8')
style = xlwt.XFStyle()
font = xlwt.Font() # 创建字体
font.name = 'Arial'
font.bold = True # 黑体
font.underline = True # 下划线
font.italic = True # 斜体字
font.colour_index = 2 # 颜色为红色
style.font = font
worksheet.write(row, column, "memeda", style)
workbook.save('memeda.xls')

 

输出多种颜色字体

import xlwt

workbook = xlwt.Workbook(encoding='utf-8')


def get_style(i):
    style = xlwt.XFStyle()
    font = xlwt.Font()  # 创建字体
    font.colour_index = i
    style.font = font
    return style


sheet = workbook.add_sheet("memeda")
for i in range(0, 100):
    sheet.write(i, 0, "memeda", get_style(i))
workbook.save('memeda.xls')

 

import xlrd
import os


file = os.getcwd()+'\\pp.xls'
def read_excel():

    wb = xlrd.open_workbook(filename=file)#打开文件
    # 通过碎银获取sheel
    table = wb.sheets()[0]
    print(table)
    table = wb.sheets()[1]
    print(table)
    # 通过索引顺序获取sheet
    table = wb.sheet_by_index(0)
    print(table.name)
    print(table.ncols)
    print(table.read)
    print(table)
    table = wb.sheet_by_index(1)
    print(table)
    # 通过名称获取sheet
    table = wb.sheet_by_name("Sheet1")
    print(table)
    table = wb.sheet_by_name("Sheet2")
    print(table.name)
    # 返回book中所有sheet的名字
    table = wb.sheet_names()
    print(table)
    # 传入索引或sheet名检查某个sheet是否导入完毕
    ta = wb.sheet_loaded("Sheet1")
    print(ta)
    ta = wb.sheet_loaded(0)
    print(ta)
    table = wb.sheet_by_index(0)
    rowx = 0
    # 返回由rowx行中所有的单元格对象组成的列表

    print(table.row(rowx))
    # 获取rowx行第一个单元格的类型
    # 0. empty(空的),1 string(text), 2 number, 3 date, 4 boolean, 5 error, 6 blank(空白表格)
    print(table.row(rowx)[0].ctype)
    # 获取rowx行第一个单元格的值
    print(table.row(rowx)[0].value)
    # 返回由rowx行中所有的单元格对象组成的列表
    print(table.row_slice(rowx, start_colx=0, end_colx=None))
    # 返回由rowx行中所有单元格的数据类型组成的列表
    print(table.row_types(rowx, start_colx=0, end_colx=None))
    # 返回由rowx行中所有单元格的数据组成的列表
    print(table.row_values(rowx, start_colx=0, end_colx=None))
    # 返回rowx行的有效单元格长度
    print(table.row_len(rowx))
    # 返回colx列中所有的单元格对象组成的列表
    colx = 0
    print(table.col(colx, start_rowx=0, end_rowx=None))
    # 返回colx列中所有的单元格对象组成的列表
    print(table.col_slice(colx, start_rowx=0, end_rowx=None))
    # 返回colx列中所有单元格的数据类型组成的列表
    print(table.col_types(colx, start_rowx=0, end_rowx=None))
    # 返回colx列中所有单元格的数据组成的列表
    print(table.col_values(colx, start_rowx=0, end_rowx=None))
    # 读取sheet的单元格
    # 返回单元格对象
    print(table.cell(rowx, colx))
    # 单元格数据类型
    # 0. empty(空的),1 string(text), 2 number, 3 date, 4 boolean, 5 error, 6 blank(空白表格)
    print(table.cell(rowx, colx).ctype)
    #  返回单元格中的数据类型
    print(table.cell_type(rowx, colx))
    #  返回单元格中的数据
    print(int(table.cell_value(rowx+5, colx+4)))
    #  返回单元格中的数据



if __name__ == '__main__':

    read_excel()