zoukankan      html  css  js  c++  java
  • 第三方库xlrd,读取excel中的数据实用方法

    1、安装第三方库

    pip install xlrd

    2、导入第三方库,且将该功能进行封装,提高复用性

    import xlrd
    from xlrd import xldate_as_tuple
    '''
    xlrd中单元格的数据类型
    数字一律按浮点型输出,日期输出成一串小数,布尔型输出0或1,所以我们必须在程序中做判断处理转换
    成我们想要的数据类型
    0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
    '''
    class ExcelData():
        # 初始化方法
        def __init__(self, data_path, sheetname):
            #定义一个属性接收文件路径
            self.data_path = data_path
            # 定义一个属性接收工作表名称
            self.sheetname = sheetname
            # 使用xlrd模块打开excel表读取数据
            self.data = xlrd.open_workbook(self.data_path)
            # 根据工作表的名称获取工作表中的内容(方式①)
            self.table = self.data.sheet_by_name(self.sheetname)
            # 根据工作表的索引获取工作表的内容(方式②)
            # self.table = self.data.sheet_by_name(0)
            # 获取第一行所有内容,如果括号中1就是第二行,这点跟列表索引类似
            self.keys = self.table.row_values(0)
            # 获取工作表的有效行数
            self.rowNum = self.table.nrows
            # 获取工作表的有效列数
            self.colNum = self.table.ncols
    
        # 定义一个读取excel表的方法
        def readExcel(self):
            # 定义一个空列表
            datas = []
            for i in range(1, self.rowNum):
                # 定义一个空字典
                sheet_data = {}
                for j in range(self.colNum):
                    # 获取单元格数据类型
                    c_type = self.table.cell(i,j).ctype
                    # 获取单元格数据
                    c_cell = self.table.cell_value(i, j)
                    if c_type == 2 and c_cell % 1 == 0:  # 如果是整形
                        c_cell = int(c_cell)
                    elif c_type == 3:
                        # 转成datetime对象
                        date = datetime.datetime(*xldate_as_tuple(c_cell,0))
                        c_cell = date.strftime('%Y/%d/%m %H:%M:%S')
                    elif c_type == 4:
                        c_cell = True if c_cell == 1 else False
                    sheet_data[self.keys[j]] = c_cell
                    # 循环每一个有效的单元格,将字段与值对应存储到字典中
                    # 字典的key就是excel表中每列第一行的字段
                    # sheet_data[self.keys[j]] = self.table.row_values(i)[j]
                # 再将字典追加到列表中
                datas.append(sheet_data)
            # 返回从excel中获取到的数据:以列表存字典的形式返回
            return datas
    if __name__ == "__main__":
        def num(x,y):
            data_path = date_path
            sheetname = "Sheet1"
            get_data = ExcelData(data_path, sheetname)
            datas = get_data.readExcel()
            print(datas)
  • 相关阅读:
    2019 Multi-University Training Contest 4
    AC自动机
    trie
    Contest1802
    蓝桥杯-某电视台举办了低碳生活大奖赛
    蓝桥杯-有一群海盗(不多于20人),在船上比拼酒量
    蓝桥杯-福尔摩斯到某古堡探险
    蓝桥杯-标题:字符串比较
    蓝桥杯-题目:猜算式
    蓝桥杯-标题:算年龄
  • 原文地址:https://www.cnblogs.com/guweimeng/p/14618981.html
Copyright © 2011-2022 走看看