在python中将xls转换为json

时间:2017-05-15 06:53:04

标签: python json xlsx xls

我正在尝试将xls转换为json,但是当我执行代码时它没有给我xls表单中的数据,它只给了我json结构。 下面是我正在运行的代码,我无法理解我应该进一步修改的内容,以便我可以获得一个完美的json文件。

请注意 - 输入采用二进制流的形式,输出也采用流而非文件的形式。

    #!/usr/bin/python -u
import sys
import xlrd
import simplejson
from collections import OrderedDict

wb = xlrd.open_workbook(file_contents=sys.stdin.read())

for sheet_index in range(wb.nsheets):
#       print sheet_index
        sh =  wb.sheet_by_index(sheet_index)
       # print "Processing sheet no ", sheet_index
        attributes = sh.row_values(0)
        #print attributes
        rows_list = []
        attr_list = []
       # print attr_list[0]

        for rownum in range(1,sh.nrows):
                row_val_list = sh.row_values(rownum)
                row_dict = OrderedDict()
                for index in range(len(attr_list)):
                        row_dict[attr_list[index]] = row_val_list[index]

                #row_dict['ID'] = row_val_list[0]
                #row_dict['Name'] = row_val_list[1]

                #rows_list.append(row_dict)

        #json_data = simplejson.dumps(rows_list)
        #sys.stdout.write(json_data)
                rows_list.append(row_dict)
                json_data = simplejson.dumps(rows_list)
                sys.stdout.write(json_data)

#       json_data = simplejson.dumps(rows_list)

        #sys.stdout.write(json_data)
~

非常感谢任何帮助

1 个答案:

答案 0 :(得分:0)

这是正确的工作python代码

#!/usr/bin/python -u
import sys
import xlrd
import simplejson
from collections import OrderedDict

wb = xlrd.open_workbook(file_contents=sys.stdin.read())

#print "Sheets are .... ", wb.nsheets

for sheet_index in range(wb.nsheets):
        sh =  wb.sheet_by_index(sheet_index)

        if sh.nrows == 0:
                continue

        attr_list = sh.row_values(0)

        rows_list = []

        for rownum in range(1,sh.nrows):
                row_values = sh.row_values(rownum)
                 row_dict = OrderedDict()

                for index in range(len(attr_list)):
                        row_dict[attr_list[index]] = row_values[index]



                rows_list.append(row_dict)

        json_data = simplejson.dumps(rows_list)
        sys.stdout.write(json_data)