python读取excel表格生成erlang数据
作者:Shay_黄 发布时间:2022-12-26 05:03:54
标签:python,excel,erlang
为了将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()
来源:http://www.cnblogs.com/huangxiaoyi/p/7434851.html


猜你喜欢
- 调用opencv库,将yuv图像转为jpg图像。代码如下:# define _CRT_SECURE_NO_WARNINGS#include
- 本篇博客主要介绍的是pyinstaller在windows下的基本使用和基础避坑在windows中使用pyinstaller工具打包时会出现
- 最近在做微信支付,调用微信的统一下单支付接口http://mch.weixin.qq.com/wiki/doc/api/jsapi.php?
- 1.条件语句几个注意点和C#不一样的。if a < 5 { return 0} else {
- 1. ORACLE 的解析器按照从右到左的顺序处理 FROM 子句中的表名,因此 FROM 子句中写在最后的表(基础表 driving ta
- 内容摘要:最近逛论坛经常看到有朋友问上传文件怎么重命名,怎么以当前日期来重命名上传文件。现在我就介绍一下重命名的方法,希望对大家有所帮助。本
- 有一个同学在Gne的群里面咨询如何通过Selenium获取当前鼠标指向的元素,在我讲了方法以后,他过了两天又来问:那么,我今天就来写一篇文章
- MySQL 处理重复数据有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复的数据。
- 序言话说在前面,我不是小黑子~我是超级大黑子😏表弟大周末的跑来我家,没事干天天骚扰我,搞得我都不能跟小姐姐好好聊天了,于是为了打发表弟,我决
- 一,extract方法的使用extract函数主要是对于数据进行提取。场景一般对于DataFrame中的一列中的数据进行提取的场合比较多。例
- 本篇文章起源于在GCR MVP Open Day的时候和C# MVP张响讨论连接池的概念而来的。因此单独写一篇文章剖析一下连接池。 为什么需
- 1。注意用SQL分析器可以看select出来的东西select right(convert(varchar(30),getdate(),12
- 很久之前曾经总结过一篇博客“MySQL如何找出未提交事务信息”,现在看来,这篇文章中不少知识点或观点都略显肤浅,或者说不够深入,甚至部分结论
- 列表的逆序遍历a = [1,3,6,8,9]print("通过下标逆序遍历1:")for i in a[::-1]: &
- python中for循环用于针对集合中的每个元素的一个代码块,而while循环能实现满足条件下的不断运行。使用while循环时,由于whil
- 1.定义aiohttp 是一个基于 asyncio 的异步 HTTP 网络模块,它既提供了服务端,又提供了客户端2.基本使用import a
- 一、简介我们知道在购买股票的时候,可以使用历史数据来对当前的股票的走势进行预测,这就需要对股票的数据进行获取并且进行一定的分析,当然了,人们
- 以下代码以Python3.6.1为例hashlib : 不可逆加密hmac : 不可逆键值对方式加密hashlib模块简介:hashlib模
- 纯粹的截取字符串其实比较简单,用一个Left就搞定,但一个是全英文标题,一个是全中文标题,或中文混合排在一起,长短不一就很明显了,要考虑到中
- 本文实例讲述了Python实现PS滤镜的万花筒效果。分享给大家供大家参考,具体如下:这里用 Python 实现 PS 的一种滤镜效果,称为万