У меня есть фрейм данных, содержащий
user_id date browser conversion test sex age country
1 2015-12-03 IE 1 0 M 32.0 US
Это весь мой код!
data["country"].fillna("missing")
data["age"].fillna(-10000, inplace=True)
data["ads_channel"].fillna("missing")
data["sex"].fillna("missing")
data['date'] = pd.to_datetime(data.date)
columns = data.columns.tolist()
columns = [c for c in columns if c not in ["test"]]
from sklearn import tree
clf = tree.DecisionTreeClassifier(max_depth=2, min_samples_leaf = (len(data)/100) )
clf = clf.fit(data[columns],data["test"])
Я получаю эту ошибку:
---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-560-95a8a54aa939> in <module>()
4 from sklearn import tree
5 clf = tree.DecisionTreeClassifier(max_depth=2, min_samples_leaf = (len(data)/100) )
----> 6 clf = clf.fit(data[columns],data["test"])
C:\Users\SnehaPriya\Anaconda2\lib\site-packages\sklearn\tree\tree.pyc in fit(self, X, y, sample_weight, check_input, X_idx_sorted)
152 random_state = check_random_state(self.random_state)
153 if check_input:
--> 154 X = check_array(X, dtype=DTYPE, accept_sparse="csc")
155 if issparse(X):
156 X.sort_indices()
C:\Users\SnehaPriya\Anaconda2\lib\site-packages\sklearn\utils\validation.pyc in check_array(array, accept_sparse, dtype, order, copy, force_all_finite, ensure_2d, allow_nd, ensure_min_samples, ensure_min_features, warn_on_dtype, estimator)
371 force_all_finite)
372 else:
--> 373 array = np.array(array, dtype=dtype, order=order, copy=copy)
374
375 if ensure_2d:
TypeError: float() argument must be a string or a number
Я все еще учусь программировать и хотел бы знать, как преодолеть эту ошибку. Любая помощь будет высоко ценится!
2 ответа
IIUC, вам также необходимо исключить столбец date
:
columns = [c for c in columns if c not in ["test", 'date']]
Потому что ошибка:
TypeError: аргумент float () должен быть строкой или числом, а не меткой времени
Решение, сохраняющее столбец даты (времени):
data['date'] = pd.to_numeric(pd.to_datetime(data['date']))
Похожие вопросы
Связанные вопросы
Новые вопросы
python
Python — это мультипарадигмальный многоцелевой язык программирования с динамической типизацией. Он предназначен для быстрого изучения, понимания и использования, а также обеспечивает чистый и унифицированный синтаксис. Обратите внимание, что Python 2 официально не поддерживается с 01.01.2020. Если у вас есть вопросы о версии Python, добавьте тег [python-2.7] или [python-3.x]. При использовании варианта Python (например, Jython, PyPy) или библиотеки (например, Pandas, NumPy) укажите это в тегах.
inplace=True
вdata["country"].fillna("missing")
data["ads_channel"].fillna("missing")
иdata["sex"].fillna("missing")
data["country"].fillna("missing", inplace=True) data["ads_channel"].fillna("missing", inplace=True) data["sex"].fillna("missing", inplace=True)
data[["country", "ads_channel", "sex"]] = data[["country", "ads_channel", "sex"]].fillna("missing")