python3实现excel转csv

xingyun86 2019-11-16 1920

1.安装python3

https://www.python.org/downloads/

2.安装依赖

python3 -m pip install xlrd

3.转换脚本保存为xls2csv.py

import logging
import time
import traceback
import xlrd
import csv
import sys
import re
 
logging.basicConfig(level=logging.INFO, format='%(asctime)s %(message)s')
def csv_from_excel():
    xls = sys.argv[1]
    target = sys.argv[2]
 
    logging.info("Start converting: From '" + xls + "' to '" + target + "'. ")
 
    try:
        start_time = time.time()
        wb = xlrd.open_workbook(xls)
        sh = wb.sheet_by_index(0)
 
        csvFile = open(target, 'w', newline='')
        wr = csv.writer(csvFile, quoting=csv.QUOTE_ALL)
 
        for row in range(sh.nrows):
            rowValues = sh.row_values(row)
 
            newValues = []
            for s in rowValues
                strValue = (str(s))
 
                isInt = bool(re.match("^([0-9]+)\.0$", strValue))
 
                if isInt:
                    strValue = int(float(strValue))
                else:
                    isFloat = bool(re.match("^([0-9]+)\.([0-9]+)$", strValue))
                    isLong  = bool(re.match("^([0-9]+)\.([0-9]+)e\+([0-9]+)$", strValue))
 
                    if isFloat:
                        strValue = float(strValue)
 
                    if isLong:
                        strValue = int(float(strValue))
 
                newValues.append(strValue)
 
            wr.writerow(newValues)
 
        csvFile.close()
 
        logging.info("Finished in %s seconds", time.time() - start_time)
 
    except Exception as e:
        print (str(e) + " " +  traceback.format_exc())
 
 
csv_from_excel()


×
打赏作者
最新回复 (0)
只看楼主
全部楼主
返回