Auto_ML自动机器学习之TPOT——学习笔记(2)

数据预处理

mat文件格式转化为csv

环境 Win10+Python3.6.8+Pycharm

import pandas as pd
import scipy
from scipy import io
features_struct = scipy.io.loadmat('E:\Auto_ML_datasets\12k Drive End Bearing Fault Data\A_1hp\A_data_0.mat')
features = features_struct['X098_DE_time']
dfdata = pd.DataFrame(features)
datapath1 = 'E:\\Auto_ML_datasets\\12k Drive End Bearing Fault Data\\A_1hp\\A_data_0.csv'
dfdata.to_csv(datapath1, index=False)

批量读取文件路径

import os
def iterbrowse(path):
    for home, dirs, files in os.walk(path):
        for filename in files:
            yield os.path.join(home, filename)
for fullname in iterbrowse('E:\\Auto_ML_datasets\\12k Drive End Bearing Fault Data\\A_1hp\\'):
    print (fullname)

整合——批量mat转csv多文件合并

import pandas as pd
import numpy as np
import scipy
from scipy import io
import os

#批量读取文件路径
def iterbrowse(path):
    for home, dirs, files in os.walk(path):
        for filename in files:
            yield os.path.join(home, filename)
#mat转csv
def mat_to_csv(mat_read_path,csv_save_path):
    features_struct = scipy.io.loadmat(mat_read_path)
    for features_key in list(features_struct.keys()):
        if 'DE' in features_key:
            features = features_struct[features_key]
            dfdata = pd.DataFrame(features)
            dfdata = dfdata.T
            features_T=np.transpose(features)
            features_list=(features_T.tolist())[0]
            DE_all_list.append(features_list)
            datapath1 =[csv_save_path+'\\'+str(i)+'DE.csv']
            dfdata.to_csv(datapath1[0], header=False, index=False)

i=0
DE_all_list=[]
for fullname in iterbrowse('E:\\Auto_ML_datasets\\12k Drive End Bearing Fault Data\\A_1hp'):
    mat_to_csv(fullname,'E:\\Auto_ML_datasets\\12k Drive End Bearing Fault Data\\csv')
    i = i + 1
DE_all_array=pd.DataFrame(DE_all_list)
DE_all_array.to_csv('E:\\Auto_ML_datasets\\12k Drive End Bearing Fault Data\\csv\\DE_all_array.csv', header=False, index=False)
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值