项目需要一个从excel导出lua配置表的工具,之前的工具是主程写的,效率极差,i7 CPU 一次全部导出要花掉1个多小时。匪夷所思的是,这么渣的效率,居然用了整整一年。当

然,中途有人反映效率差,主程直接无视了,随着呼声越来越高,主程终于有空行动了。

  一天下来,主程宣布,其工具效率提升了近50%,并且说了很多非专业人士听不懂的话,什么换库了,什么小文件没法提速,什么python效率就是这么差……

当即就有同志体验了改进过的工具,导出某几个文件速度的的确确,确确实实,实实在在提升了50%,于是公司内部群里好几个同志对主程竖起了大拇指,主程表示举手之劳,不足以

挂齿,随即便在公司论坛发帖《转:python之excel哪家强》,内容是介绍python几个常用excel库的优劣,以及自己在考虑众多因素之后果断的抉择。

  在无比佩服的同时,我决定重写这个工具,一接手,深似海,非常不规范的excel表,非常不灵活的格式,还有大堆针对某些表的特殊处理,整个设计用一句话来形容:跪了。

在折腾了一天之后终于搞定了,跟原工具用一样的库openpyxl,兼容99.9%原配置表,而性能却比之前改进过的工具快了230倍左右。

  废话说了一大堆。

支持类型:

int,bool,float,string,

struct<[int,bool,float,string]...>,

list<int>,

list<bool>,

list<float>,

list<string>,

list<struct<[int,bool,float,string]...>>,

填写格式:

line 1: 注释

line 2: 字段类型:字段名字 => int:name | list<int:>:name | struct<int:n1,int:n2>:name

line 3:内容

line N:内容

源码:

 # -*- coding:utf-8 -*- 

 #    excel 导出 lua 表
 #    支持类型,int,bool,float,string,list,struct,list<int>,list<bool>,list<float>,list<string>,list<struct>

 import openpyxl
 import codecs
 import time

 TInt = "int"
 TList = "list"
 TBool = "bool"
 TFloat = "float"
 TString = "string"
 TStruct = "struct"

 def ValToKey(val):
     return val.isdecimal() and "[" + val + "]" or val

 def CheckInt(data, args = None):
     return data

 def CheckBool(data, args = None):
     " == data and "false" or "true"

 def CheckFloat(data, args = None):
     return data

 def CheckString(data, args = None):
     return "\"" + data.replace("\n", "\\n") + "\""

 def CheckList(data, args):
     vals = data.split(";")
     vals.pop()
     if len(vals) == 0:
         return ""
     func = args[0]["func"]
     args = args[0]["args"]
     array = [func(v, args) for k, v in enumerate(vals)]
     return "{ " + ", ".join(array) + " }"

 def CheckStruct(data, args):
     vals = data.split(",")
     vals.pop()
     if len(vals) == 0:
         return ""
     array = []
     for k, v in enumerate(vals):
         val = args[k]["func"](v, args[k]["args"])
         name = args[k]["name"]
         if len(val) != 0:
             array.append(name + " = " + val)
     return "{ " + ", ".join(array) + " }"

 def GetValue(sheet, row, col):
     return unicode(sheet.cell(row = row, column = col).value or "")

 def GetLine(sheet, row):
     return [GetValue(sheet, row, col) for col in xrange(1, sheet.max_column + 1)]

 def CheckParses(fields):
     result = []
     for k, field in enumerate(fields):
         pos = field.rfind(":")
         type = field[0:pos]
         name = field[pos+1:]
         parse = { "args": None }
         if TInt == type[:len(TInt)]:
             parse["func"] = CheckInt
         elif TBool == type[:len(TBool)]:
             parse["func"] = CheckBool
         elif TFloat == type[:len(TFloat)]:
             parse["func"] = CheckFloat
         elif TString == type[:len(TString)]:
             parse["func"] = CheckString
         elif TList == type[:len(TList)]:
             parse["func"] = CheckList
             parse["args"] = CheckParses([type[len(TList)+1:-1]])
         elif TStruct == type[:len(TStruct)]:
             parse["func"] = CheckStruct
             parse["args"] = CheckParses(type[len(TStruct)+1:-1].split(","))
         if len(name) == 0:
             parse["name"] = ValToKey(unicode(k))
         else:
             parse["name"] = ValToKey(name)
         result.append(parse)
     return result

 def CheckChunk(parses, fields):
     chunk = []
     for index, field in enumerate(fields):
         key = parses[index]["name"]
         val = parses[index]["func"](field, parses[index]["args"])
         if len(val) != 0:
             chunk.append(key + " = " + val)
     return "{ " + ", ".join(chunk) + " }"

 def Export(sheet):
     #    第一行注释
     #    第二行类型
     parses = CheckParses(GetLine(sheet, 2))
     #    第三行内容
     chunks, indexs, parse0 = [], [], parses[0]
     for row in xrange(3, sheet.max_row + 1):
         value = GetValue(sheet, row, 1)
         index = parse0["func"](value, parse0["args"])
         indexs.append(index)

         chunk = CheckChunk(parses, GetLine(sheet, row))
         chunks.append("%s = %s" % (ValToKey(index), chunk))
         print row, index

     result = [    "return ", \
                 "{ " + "\n".join(chunks) + " }", \
                 ",", \
                 "{ " + ", ".join(indexs) + " }",]
     return "\n".join(result)

 def Main(opath, ipath):
     xlsx = openpyxl.load_workbook(opath)
     sheet = xlsx.get_sheet_by_name(xlsx.sheetnames[0])
     result = Export(sheet)
     with codecs.open(ipath, "w", "utf-8") as f:
         f.write(result)

 if __name__ == "__main__":
     Main("D:\\MyWork\\py\\a.xlsx", "D:\\MyWork\\py\\a.lua")

因为公司项目配置表格式很烂,所以这一份是另外写的,方便以后我自己用的,未经测试!!!

下载

记录——excel导出lua工具(python实现)的更多相关文章

  1. [tools]excel转lua的python实现

    time:2015/04/13 描述:需要将excel表格内容转成lua,并且作为工具使用,能够批量转换 步骤: (1)文章[1]已经做了大部分的内容,而且也已经能够使用了 (2)根据自己新的需求: ...

  2. 一个把数据转化成Excel导出的程序 python Django

    把从数据库查询出来数据导出 源码下载!!!!! 效果图 登入界面 主页面 查询到数据 导出 打开得到文件 项目地址,源码下载

  3. java excel导出(基于注解)

    小白,做日志只是为了方便自己查看,能帮到别人当然更好,不喜勿喷. 上代码 依赖: <dependency> <groupId>org.apache.poi</groupI ...

  4. Python导出Excel为Lua/Json/Xml实例教程(三):终极需求

    相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 Python导出E ...

  5. Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验

    Python导出Excel为Lua/Json/Xml实例教程(二):xlrd初体验 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出E ...

  6. Python导出Excel为Lua/Json/Xml实例教程(一):初识Python

    Python导出Excel为Lua/Json/Xml实例教程(一):初识Python 相关链接: Python导出Excel为Lua/Json/Xml实例教程(一):初识Python Python导出 ...

  7. 偷懒小工具 - Excel导出公共类

    说明 最近接了一个任务,就是做一个列表的Excel导出功能.并且有很多页面都会使用这个功能. 导出的Excel大体格式如图 很简单的列表,标题加背景色,然后不同类型,显示方式不一样.对齐方式不一样.不 ...

  8. 自己写的java excel导出工具类

    最近项目要用到excel导出功能,之前也写过类似的代码.因为这次项目中多次用到excel导出.这次长了记性整理了一下 分享给大伙 欢迎一起讨论 生成excel的主工具类: public class E ...

  9. .NET开发工具之Excel导出公共类

    来源:Pino晨 链接:cnblogs.com/chenxygx/p/5954870.html 说明 最近接了一个任务,就是做一个列表的Excel导出功能.并且有很多页面都会使用这个功能. 导出的Ex ...

随机推荐

  1. NOI全国赛(2001)--食物链

    今天写了道并查集的题,看来并查集的题刷少了,,,,,用法好神奇啊!!!开三倍并查集 用i表示自己,i+n存天敌,i+2*n存可以克制de,再逻辑判断一下即可. 所以,要意识到并查集的分类处理可以开不同 ...

  2. db2 sequence 查询

    1. 查询名字 select * from sysibm.sysequences where seqname='wx_Id' 2.nextVal select wx_seq_id.currval fr ...

  3. flask框架+pygal+sqlit3搭建图形化业务数据分析平台

    一. 前言 先说下主要的框架和主要的图形库的特点:(个人见解) Django:python开发的一个重量级的web框架,集成了MVC和ORM等技术,设计之初是为了使开发复杂的.数据库驱动的网站变得简单 ...

  4. JSP九大内置对象的作用和用法总结(转)

    SP中一共预先定义了9个这样的对象,分别为:request.response.session.application.out.pagecontext.config.page.exception 1.r ...

  5. Apache优化

    控制MaxClients的设置,以避免服务器产生太多的子进程而发生交换.进程间的数据交换会占用很大内存,数据交换产生的滞后使用户总感觉"不够快",所以用户就可能去按"停止 ...

  6. Java基础之面试题

    本文我们将要讨论Java面试中的各种不同类型的面试题,它们可以让雇主测试应聘者的Java和通用的面向对象编程的能力.下面的章节分为上下两篇,第一篇将要讨论面向对象编程和它的特点,关于Java和它的功能 ...

  7. 浓缩的才是精华:浅析GIF格式图片的存储和压缩

    成文迪, 在Web前端摸爬滚打的码农一枚,对技术充满热情的菜鸟,致力为手Q的建设添砖加瓦. GIF格式的历史 GIF(Graphics Interchange Format)原义是"图像互换 ...

  8. 修改数据库用户名--CMD环境执行有效

    --CMD环境执行有效 --修改数据库用户名 select * from user$ where name='aa';   update user$ set name='bb' where name  ...

  9. Java基础学习(二)—数组

    一.数组的概念 定义: 数组是存储同一种数据类型的多个元素的集合. 数组既可以存储基本数据类型,也可以存储引用数据类型. 格式: 格式1: 数据类型[] 数组名; 格式2: 数据类型 数组名[]; 这 ...

  10. List分组 用于客服对话分组场景

    工作用可能会用到会话分组: Message是消息实体对象,里面有toId和fromId 指明接收方ID和发送方Id,通过组合形式"12-22-" 为map的key public M ...