为了将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
# excel
# erlang
# python读取文件夹中图片的图片名并写入excel表格
# Python读取pdf表格写入excel的方法
# 解决python pandas读取excel中多个不同sheet表格存在的问题
# Python3读取和写入excel表格数据的示例代码
# python读取Excel表格文件的方法
# python3 读取Excel表格中的数据
# Python读取Excel表格
# 并同时画折线图和柱状图的方法
# python实现读取excel表格详解方法
# 分页
# 遍历
# 有什么
# 第一个
# 找不到
# 两天
# 写了
# 会很
# 转换成
# 所需要
# 学了
# 读到
# 大家多多
# 不包含
# 地方请
# 行数
# 加载
# 第三行
# load_workbook
# os
相关文章:
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
如何注册花生壳免费域名并搭建个人网站?
高防服务器租用指南:配置选择与快速部署攻略
如何用VPS主机快速搭建个人网站?
网站制作公司,橙子建站是合法的吗?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
岳西云建站教程与模板下载_一站式快速建站系统操作指南
如何构建满足综合性能需求的优质建站方案?
国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
如何高效利用亚马逊云主机搭建企业网站?
购物网站制作公司有哪些,哪个购物网站比较好?
宝塔建站教程:一键部署配置流程与SEO优化实战指南
如何通过cPanel快速搭建网站?
定制建站策划方案_专业建站与网站建设方案一站式指南
香港服务器网站卡顿?如何解决网络延迟与负载问题?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
建站主机如何选?高性价比方案全解析
长沙做网站要多少钱,长沙国安网络怎么样?
网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?
ppt制作免费网站有哪些,ppt模板免费下载网站?
桂林网站制作公司有哪些,桂林马拉松怎么报名?
如何在新浪SAE免费搭建个人博客?
建站之星代理费用多少?最新价格详情介绍
如何通过远程VPS快速搭建个人网站?
济南专业网站制作公司,济南信息工程学校怎么样?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
如何在IIS服务器上快速部署高效网站?
如何使用Golang安装API文档生成工具_快速生成接口文档
建站之星如何实现网站加密操作?
如何快速登录WAP自助建站平台?
如何在IIS中新建站点并配置端口与IP地址?
如何通过网站建站时间优化SEO与用户体验?
建站VPS选购需注意哪些关键参数?
如何用PHP快速搭建高效网站?分步指南
开封网站制作公司,网络用语开封是什么意思?
网站设计制作企业有哪些,抖音官网主页怎么设置?
Python如何创建带属性的XML节点
建站主机选购指南:核心配置优化与品牌推荐方案
建站主机与服务器功能差异如何区分?
东莞专业制作网站的公司,东莞大学生网的网址是什么?
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
建站三合一如何选?哪家性价比更高?
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?
大学网站设计制作软件有哪些,如何将网站制作成自己app?
建站之星代理如何优化在线客服效率?
html制作网站的步骤有哪些,iapp如何添加网页?
如何在阿里云ECS服务器部署织梦CMS网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。