为了将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()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年11月25日
2024年11月25日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]