将Excel文件转为csv文件的python脚本
admin
2023-07-19 08:42:37
0
#!/usr/bin/env python 
__author__ = "lrtao2010"
'''
Excel文件转csv文件脚本
需要将该脚本直接放到要转换的Excel文件同级目录下
支持xlsx 和 xls 格式
在同级目录下生成名为excel_to_csv.csv 的文件,采用UTF-8编码
'''
import xlrd
import csv
import os
#生成的csv文件名
csv_file_name = 'excel_to_csv.csv'
def get_excel_list():
    #获取Excel文件列表
    excel_file_list = []
    file_list = os.listdir(os.getcwd())
    for file_name in file_list:
        if file_name.endswith('xlsx') or file_name.endswith('xls'):
            excel_file_list.append(file_name)
    return excel_file_list
def get_excel_header(excel_name_for_header):
    #获取表头,并将表头全部变为小写
    workbook = xlrd.open_workbook(excel_name_for_header)
    table = workbook.sheet_by_index(0)
    #row_value = table.row_values(0)
    row_value = [i.lower() for i in table.row_values(0)]
    return row_value
def read_excel(excel_name):
    #读取Excel文件每一行内容到一个列表中
    workbook = xlrd.open_workbook(excel_name)
    table = workbook.sheet_by_index(0) #读取第一个sheet
    nrows = table.nrows
    ncols = table.ncols
    # 跳过表头,从第一行数据开始读
    for rows_read in range(1,nrows):
        #每行的所有单元格内容组成一个列表
        row_value = []
        for cols_read in range(ncols):
            #获取单元格数据类型
            ctype = table.cell(rows_read, cols_read).ctype
            #获取单元格数据
            nu_str = table.cell(rows_read, cols_read).value
            #判断返回类型
            # 0 empty,1 string, 2 number(都是浮点), 3 date, 4 boolean, 5 error
            #是2(浮点数)的要改为int
            if ctype == 2:
                nu_str = int(nu_str)
            row_value.append(nu_str)
        yield row_value

def xlsx_to_csv(csv_file_name,row_value):
    #生成csv文件
    with open(csv_file_name, 'a', encoding='utf-8',newline='') as f: #newline=''不加会多空行
        write = csv.writer(f)
        write.writerow(row_value)
if __name__ == '__main__':
    #获取Excel列表
    excel_list = get_excel_list()
    #获取Excel表头并生成csv文件标题
    xlsx_to_csv(csv_file_name,get_excel_header(excel_list[0]))
    #生成csv数据内容
    for excel_name in  excel_list:
        for row_value in read_excel(excel_name):
            xlsx_to_csv(csv_file_name,row_value)
    print('Excel文件转csv文件结束 ')

相关内容

热门资讯

雷军现身武汉,路边坐小板凳吃早... “我和雷军一起过早了!”“撂下筷子就去合照!”据武汉市文化和旅游局公众号,6月15日清晨,雷军闪现武...
美议员:特朗普一个目标都没实现... 当地时间6月14日,美国宣布与伊朗达成了谅解备忘录,使得局势降温,并为后续谈判打下基础。谅解备忘录将...
缅甸总统敏昂莱抵达北京 今天(6月15日)下午,缅甸总统敏昂莱抵达北京,开启为期五天的访华行程。这也是敏昂莱当选总统以来首次...
轰炸声中,和平协议谈妥了 6月14日,美国总统特朗普迎来80岁生日。他原本计划在“这个特殊日子”与伊朗签署终战协议,给这场历时...
老鼠、蛆虫、农残等食品安全问题... 快科技6月15日消息,针对一段时期以来监管发现和媒体曝光的山姆线下门店及线上网店多发的食品安全问题。...
京东健康将与北京友谊医院共建消... IT之家 6 月 13 日消息,“京东健康黑板报”公众号 13 日(今天)发文宣布,京东健康与首都医...
星河动力航天:谷神星二号(遥一... 6 月 15 日消息,星河动力航天今日宣布,谷神星二号(遥一)运载火箭飞行故障通过归零评审。 近日,...
德日再走向军事大国?特朗普一句... 【文/观察者网 柳白】二战结束八十多年后,国际安全格局迎来持续动荡,二战战败国德国与日本的军备动向再...
广汽与华为乾崑联合打造:启境获... 6月14日消息,据新浪汽车报道,6 月 13 日,在 2026 中国汽车重庆论坛上,启境汽车 CEO...
“无招”没错,他只是老了 文 | 有界UnKnown 还是想再聊聊钉钉,也聊聊无招。 我觉得这件事对很多打工人,以及很多高管...