博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Matlab数据转化至python端,并写入数据库
阅读量:6279 次
发布时间:2019-06-22

本文共 1212 字,大约阅读时间需要 4 分钟。

因工作原因,一些获取的行业数据以已知的结构体存储在.mat文件中,

现需要将其存储在数据库中并且能够灵活调用至python dataframe里进行操作

 

原数据的一个例子如下

目标如上:

然后是转化代码:

import scipy.iodata = scipy.io.loadmat(r'C:\Users\wenzhe.tian\Desktop\PTSimA\Doing\MC.mat')import pandas as pddata.pop('__header__')data.pop('__version__')data.pop('__globals__')vehicle_name=data.keys()vehicle_name=list(vehicle_name)for i in vehicle_name:    df = pd.DataFrame(data[i][0])    try:        df=df.astype(float)    except:        for j in list(df):            try:                df[j]=df[j].astype(float)            except:                continue#                df[j]=df[j].astype(str)    if i==vehicle_name[0]:        df1=df;    else:        df1=pd.concat([df,df1],axis=0)df1['MC_name']=vehicle_namedf1['Tips']=df1['Tips'].map(str)+df1['tips'].map(str)df1['Tips']=df1['Tips'].str.replace('nan','')df1=df1.drop(['tips'],axis=1)df1=df1.reset_index();import numpy as np# ndarray需转化为 字符list_transfer=['Speed','Torque','eff','eff_current']for i in list_transfer:    for j in range(len(df1)):        try:            df1[i][j]=df1[i][j].tostring();        except:            continue;
View Code

结果如下(df1):

然后用to_sql的方式将该dataframe 保存至本地sql数据库即可

 

转载于:https://www.cnblogs.com/techs-wenzhe/p/10931566.html

你可能感兴趣的文章
input checkbox 复选框大小修改
查看>>
网吧维护工具
查看>>
BOOT.INI文件参数
查看>>
vmstat详解
查看>>
新年第一镖
查看>>
unbtu使用笔记
查看>>
OEA 中 WPF 树型表格虚拟化设计方案
查看>>
Android程序开发初级教程(一) 开始 Hello Android
查看>>
使用Gradle打RPM包
查看>>
“我意识到”的意义
查看>>
淘宝天猫上新辅助工具-新品填表
查看>>
再学 GDI+[43]: 文本输出 - 获取已安装的字体列表
查看>>
nginx反向代理
查看>>
操作系统真实的虚拟内存是什么样的(一)
查看>>
hadoop、hbase、zookeeper集群搭建
查看>>
python中一切皆对象------类的基础(五)
查看>>
modprobe
查看>>
android中用ExpandableListView实现三级扩展列表
查看>>
%Error opening tftp://255.255.255.255/cisconet.cfg
查看>>
java读取excel、txt 文件内容,传到、显示到另一个页面的文本框里面。
查看>>