mat格式转换成csv格式

论坛 期权论坛 脚本     
匿名技术用户   2021-1-5 03:52   14   0
最近发现了一个超好的工具  也可以说是代码   值得推广    能够吧mat格式批量转变成csv格式  超赞   网上的大部分都不是特别好,很多代码都不能很好的运行,现在有个Python版本的,分享给大家
# coding=utf-8
import scipy.io as sio
import pandas as pd
import os
def mat2csv():
    """ 将当前目录下的data目录下的 .mat 文件转换成多个 .csv文件 :return: """
    curr_path = os.path.dirname(__file__)
    mat_data_path = os.path.join(curr_path, "data")
    csv_data_path = os.path.join(curr_path, "csv")
    if not os.path.exists(csv_data_path):
        os.makedirs(csv_data_path)
    if not os.path.exists(mat_data_path):
        os.makedirs(mat_data_path)
    file_list = os.listdir(mat_data_path)
    mat_list = [file_name for file_name in file_list if file_name.endswith(".mat")]
    print "find mat file : ", mat_list



    for mat_file in mat_list:
        file_path = os.path.join(mat_data_path, mat_file)
        mat_data = sio.loadmat(file_path)
        version = str(mat_data.get("__version__", "1.0")).replace(".", "_")
        for key in mat_data.iterkeys():
            if not str(key).startswith("__"):
                data = mat_data[key][:]
                print mat_file
                try:
                    dfdata = pd.DataFrame(data)
                except ValueError as e:
                    print e.message
                    continue
                csv_name = "_".join([mat_file.split(".")[0], key, version, '.csv'])
                csv_path = os.path.join(csv_data_path, csv_name)
                dfdata.to_csv(csv_path)
if __name__ == "__main__":
    mat2csv()
分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP