我能够在DataFrame中获取数据from here。当我使用graphlab将DataFrame转换为SFrame时,会显示以下错误:
TypeError:不能从float,string类型中输入常见类型。
我的代码是
import graphlab
import pandas as pd
import numpy as np
import matplotlib.pyplot as pt
from numpy import array
from graphlab import SFrame
user_columns =['No','User id','User Name','Skill','Given Test Name','Given Test ID','Recommend Test','Recommend Test ID','Time Start','Time End','Score','Max Score']
data=pd.read_table('http://tech4partner.com.cp-in-5.webhostbox.net/recommend_test.php', sep='^',header=None,names = user_columns)
df2 = data.ix[2:]
df3=df2.reset_index()
df4=df3.drop('index', axis=1)
df5=df4.drop(df4.index[len(df4)-1])
df5=df5.reset_index(1,[len(df5)-1])
df7 = df5.reset_index()
df8=df7.drop('index', axis=1)
df9=df8.head(len(df8))
df9.index = np.arange(1, len(df9) + 1)
df9=df9.head(50)
df9
数据显示在此行的DataFrame中。当我将DataFrame转换为Sframe时,它会出错。
DataFrame使用.Sframe()方法转换为SFrame
t_data = graphlab.SFrame(df9)
T_DATA
并且根据我的数据格式正确或可能不是。而且我尝试了两种解决方案,但它对我没有用。
1)我检查了每一列,但没有列有不同的数据类型。
2)我使用
转换了特定数据类型中的每一列 df.column_name.astype(str)
和df [' column_name'] = df [coulmn_name] .astype(str)
但它已经不再适用了。
TypeError Traceback (most recent call last)
<ipython-input-11-c852cd1e7f45> in <module>()
----> 1 t_data = graphlab.SFrame(df9)
2 t_data
3
C:\Anaconda2\lib\site-packages\graphlab\data_structures\sframe.pyc in __init__(self, data, format, _proxy)
951 pass
952 else:
--> 953 raise ValueError('Unknown input type: ' + format)
954
955 sframe_size = -1
C:\Anaconda2\lib\site-packages\graphlab\cython\context.pyc in __exit__(self, exc_type, exc_value, traceback)
47 if not self.show_cython_trace:
48 # To hide cython trace, we re-raise from here
---> 49 raise exc_type(exc_value)
50 else:
51 # To show the full trace, we do nothing and let exception propagate
**TypeError: A common type cannot be infered from types float, string.**
如何将此DataFrame转换为SFrame?
答案 0 :(得分:0)
尝试使用此语法进行转换:
df['column_name'] = df['column_name'].astype(float)
df['column_name'] = df['column_name'].astype(str)