python读取excel数据生成新的表格_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()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持聚米学院。

参与评论 您还未登录,请先 登录 后发表或查看评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:1024 设计师:我叫白小胖 返回首页

打赏作者

weixin_39716043

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值