zoukankan      html  css  js  c++  java
  • python 读取xls文件

    import xlrd
    from xlrd import xldate_as_tuple
    from IPScriptUtil import *
    from serverTest import *
    import re
    import datetime
    '''
    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(1)
    self.keys =["ip","deploy_unit"]
    # 获取工作表的有效行数
    self.rowNum = self.table.nrows
    # 获取工作表的有效列数
    self.colNum = self.table.ncols

    # 定义一个读取excel表的方法
    def readExcel(self):
    # 定义一个空列表
    datas = []
    for i in range(0, 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/%m/%d %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
    def convertPort(self,port):
    try:
    int(port)
    except Exception: # not a valid port
    return False
    return True

    if __name__ == "__main__":
    data_path = "D:/虚拟机列表信息.xls"
    sheetname = "Sheet1"
    get_data = ExcelData(data_path, sheetname)
    datas = get_data.readExcel()
    print(len(datas))
    if len(datas) >=1:
    for index in range(len(datas)):
    print(datas[index].get("ip")+datas[index].get("deploy_unit"))










  • 相关阅读:
    CE工具里自带的学习工具--第三关
    CE工具里自带的学习工具--第二关
    CE工具里自带的学习工具--第一关
    双向链表
    双向循环链表
    单向循环链表
    单链表
    动手动脑———异常处理
    动手动脑——继承与多态
    类与对象——动手动脑
  • 原文地址:https://www.cnblogs.com/javahepeng/p/13279965.html
Copyright © 2011-2022 走看看