python读取excel表格生成erlang数据


Posted in Python onAugust 26, 2017

为了将excel数据自动转换成所需要的erlang数据,听同事说使用python会很方便简单,就自学了两天python,写了一个比较粗糙的python脚本,不过能用,有什么优化的地方请指教

代码如下:

#!/usr/bin/env python
# -*- coding: UTF-8 -*-
import sys
from openpyxl.reader.excel import load_workbook
import os
import os.path

def gen_data(filename):
 wb = load_workbook('dataxlsx/' + filename + '.xlsx') # 加载文件所有分页

 sheetnames = wb.get_sheet_names() # 获取所有分页的名字列表
 ws = wb.get_sheet_by_name(sheetnames[0]) # 取第一个分页的数据
# print 'ws:', ws

# print "Work Sheet Titile:", ws.title # 分页名称
# print "Work Sheet Rows:", ws.max_row # 分页行数
# print "Work Sheet Cols:", ws.max_column # 分页列数

 content = [] # 数据内容
 id_list = [] # ID列表

# ========================start concat need data=================
 content.append('%% this file is auto maked!\n')
 content.append('-module(' + filename + ').\n')
 content.append('-compile(export_all).\n')

 for i in range(4, ws.max_row + 1):  # 从表格第三行开始读取,由于range函数不包含文件尾,所以为了读到最后一行需+1
  for j in range(ws.max_column):
   if ws[i][j].value == None:
    content.append(' ,""')
   elif j == 0:
    id_list.append(int(ws[i][j].value))
    content.append('get(' + str(ws[i][j].value).strip() + ') ->\n')
    content.append(' {r_' + filename + ', ' + str(ws[i][j].value).strip())
   else:
    content.append(' ,' + str(ws[i][j].value).strip())
  content.append('};\n')

 content.append('get(_) ->\n')
 content.append(' not_match.\n')

 content.append('length() ->\n')
 content.append(' ' + str(ws.max_row - 1) + '.\n')
 content.append('id_list() ->\n ' + str(id_list) + '.')
# ==============================end===========================
 # 写入数据
 f = file('./server/' + filename + '.erl','w+')
 f.writelines(content)
 print 'create new file:', filename + '.erl'
 f.close() # 关闭通道
 return

def start_gen():
 # 删除旧的数据
 delnames = os.listdir('./server')
 for delname in delnames:
  os.remove('./server/' + delname)
  print 'delete old file:', delname

 for _, _, filenames in os.walk('./dataxlsx'): # 遍历文件夹
  for filename in filenames: # 遍历文件
   find = filename.find('.xlsx') # 返回该文件名称长度
#   print "find is:", find
   if filename[0] == '~' or find == -1: # 文件名以'~'开头或者找不到文件名, 如以'.'开头的文件
    continue
   else:
    split_list = filename.split('.') # 使用'.'分割文件名,获得[文件名,文件格式]
#    print split_list
    gen_data(split_list[0]) # 用文件名作为参数调用gen_data

start_gen()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python3实现ftp服务功能(客户端)
Mar 24 Python
在CentOS6上安装Python2.7的解决方法
Jan 09 Python
python3人脸识别的两种方法
Apr 25 Python
Python实现平行坐标图的两种方法小结
Jul 04 Python
python networkx 根据图的权重画图实现
Jul 10 Python
基于python实现的百度新歌榜、热歌榜下载器(附代码)
Aug 05 Python
浅谈Django+Gunicorn+Nginx部署之路
Sep 11 Python
python爬虫-模拟微博登录功能
Sep 12 Python
Python传递参数的多种方式(小结)
Sep 18 Python
python模式 工厂模式原理及实例详解
Feb 11 Python
python获取百度热榜链接的实例方法
Aug 25 Python
python 数据类型强制转换的总结
Jan 25 Python
使用Python实现简单的服务器功能
Aug 25 #Python
详解Python实现多进程异步事件驱动引擎
Aug 25 #Python
python基础while循环及if判断的实例讲解
Aug 25 #Python
itchat和matplotlib的结合使用爬取微信信息的实例
Aug 25 #Python
用 Python 爬了爬自己的微信朋友(实例讲解)
Aug 25 #Python
详解python基础之while循环及if判断
Aug 24 #Python
用Python实现随机森林算法的示例
Aug 24 #Python
You might like
简体中文转换为繁体中文的PHP函数
2006/10/09 PHP
自动生成文章摘要的代码[PHP 版本]
2007/03/20 PHP
PHP内置的Math函数效率测试
2014/12/01 PHP
php微信公众开发之获取周边酒店信息的方法
2014/12/22 PHP
PHP简单日历实现方法
2016/07/20 PHP
JavaScript 在网页上单击鼠标的地方显示层及关闭层
2012/12/30 Javascript
jquery 触发a链接点击事件解决方案
2013/05/02 Javascript
javascript Array.prototype.slice的使用示例
2013/11/14 Javascript
JavaScript1.6数组新特性介绍以及JQuery的几个工具方法
2013/12/06 Javascript
常见的原始JS选择器使用方法总结
2014/04/09 Javascript
用jquery仿做发微博功能示例
2014/04/18 Javascript
JavaScript基础之AJAX简单的小demo
2017/01/29 Javascript
浅谈Node Inspector 代理实现
2017/10/19 Javascript
react实现菜单权限控制的方法
2017/12/11 Javascript
JS Math对象与Math方法实例小结
2019/07/05 Javascript
vue使用自定义指令实现拖拽
2021/01/29 Javascript
uni-app如何页面传参数的几种方法总结
2020/04/28 Javascript
vscode+gulp轻松开发小程序的完整步骤
2020/10/18 Javascript
[01:10]DOTA2亚洲邀请赛 征战号角响彻全场
2015/01/06 DOTA
[01:19:23]2018DOTA2亚洲邀请赛 4.5 淘汰赛 Mineski vs VG 第二场
2018/04/06 DOTA
python使用ctypes模块调用windowsapi获取系统版本示例
2014/04/17 Python
Python简单实现子网掩码转换的方法
2016/04/13 Python
详解Python 模拟实现生产者消费者模式的实例
2017/08/10 Python
linux环境下的python安装过程图解(含setuptools)
2017/11/22 Python
解决在Python编辑器pycharm中程序run正常debug错误的问题
2019/01/17 Python
树莓派采用socket方式文件传输(python)
2019/06/22 Python
Pytorch evaluation每次运行结果不同的解决
2020/01/02 Python
利用Python脚本实现自动刷网课
2020/02/03 Python
家庭户外服装:Hawkshead
2017/11/02 全球购物
山海经纬软件测试笔试题和面试题
2013/04/02 面试题
幼儿园毕业寄语
2014/04/03 职场文书
幼儿园教师节感谢信
2015/01/23 职场文书
2015年学校保卫部工作总结
2015/05/11 职场文书
2015年教师国培感言
2015/08/01 职场文书
Matlab求解数组中的最大值及它所在的具体位置
2021/04/16 Python
MySQL 原理与优化之原数据锁的应用
2022/08/14 MySQL