小编jub*_*ins的帖子

Logistic回归:如何找到权重最高的前三个特征?

我正在研究UCI乳腺癌数据集,并试图找到权重最高的前3个功能.我能够找到所有功能的重量,logmodel.coef_但我怎样才能获得功能名称?下面是我的代码,输出和数据集(从scikit导入).

from sklearn.model_selection import train_test_split
from sklearn.datasets import load_breast_cancer
from sklearn.linear_model import LogisticRegression

cancer = load_breast_cancer()
X_train, X_test, y_train, y_test = train_test_split(
    cancer.data, cancer.target, stratify=cancer.target, random_state=42)

logmodel = LogisticRegression(C=1.0).fit(X_train, y_train)
logmodel.coef_[0]
Run Code Online (Sandbox Code Playgroud)

上面的代码输出权重数组.使用这些权重如何获取关联功能名称?

Output:
    array([  1.90876683e+00,   9.98788148e-02,  -7.65567571e-02,
             1.30875965e-03,  -1.36948317e-01,  -3.86693503e-01,
            -5.71948682e-01,  -2.83323656e-01,  -2.23813863e-01,
            -3.50526844e-02,   3.04455316e-03,   1.25223693e+00,
             9.49523571e-02,  -9.63789785e-02,  -1.32044174e-02,
            -2.43125981e-02,  -5.86034313e-02,  -3.35199227e-02,
            -4.10795998e-02,   1.53205924e-03,   1.24707244e+00,
            -3.19709151e-01,  -9.61881472e-02,  -2.66335879e-02,
            -2.44041661e-01,  -1.24420873e+00,  -1.58319440e+00,
            -5.78354663e-01,  -6.80060645e-01,  -1.30760323e-01])
Run Code Online (Sandbox Code Playgroud)

谢谢.我真的很感激任何帮助.

python machine-learning feature-selection scikit-learn logistic-regression

3
推荐指数
1
解决办法
4354
查看次数

Pandas:在数据框中搜索星号时出错。例如:busiest_hosts['host'].str.contains('***.botol.dk')

下面是我的数据框的样子,您会看到我的数据框列之一是 URL,其他列是时间戳计数。当我运行此代码时:busiest_hosts[busiest_hosts['host'].str.contains('***.novo.dk')==True]我收到错误:error: nothing to repeat at position 0。我认为这是因为我的 URL 的第一个元素是*. 这看起来像是一个 python bug(我的 python 版本是 3.x)。如果有人能帮助我解决这个问题,我将非常感激。

在此输入图像描述

python r text-analysis pandas data-science

2
推荐指数
1
解决办法
2415
查看次数

熊猫:如何使用时间戳知道它的白天或黑夜?

我试图根据时间戳列表确定它是白天还是晚上.如果我只检查上午7:00到下午6:00之间的小时将其归类为"日",否则"夜晚",这是否正确?就像我在下面的代码中所做的那样.我不确定这一点,因为有时甚至在下午6点之后这一天,那么使用python来区分白天或黑夜的准确方法是什么?

sample data: (timezone= utc/zulutime)
    timestamps = ['2015-03-25 21:15:00', '2015-06-27 18:24:00', '2015-06-27 18:22:00', '2015-06-27 18:21:00', '2015-07-07 07:53:00']

Code:  
    for timestamp in timestamps:
        time = datetime.datetime.strptime(timestamp, "%Y-%m-%d %H:%M:%S")
        hr, mi = (time.hour, time.minute)
        if hr>=7 and hr<18: print ("daylight")
        else: print ("evening or night")

sample output:
evening or night
evening or night
evening or night
evening or night
daylight
Run Code Online (Sandbox Code Playgroud)

python data-analysis python-datetime pandas

0
推荐指数
1
解决办法
3143
查看次数

Pandas:如何在不使用 scikit 的情况下进行交叉验证?

我正在尝试实现我自己的交叉验证功能。我在此链接上阅读了交叉验证,并且能够将我的数据集拆分为训练和测试。但是,我如何定义折叠?例如我的数据框看起来像这样。

    Dataframe:
        MMC         MET_lep     MASS_Vis    Pt_H        Y
    0   138.70      51.65       97.82       0.91        0
    1   160.93      68.78       103.23      -999.00     0
    2   -999.00     162.17      125.95      -999.00     0
    3   143.90      81.41       80.94       -999.00     1
    4   175.86      16.91       134.80      -999.00     0
    5   -999.00     162.17      125.95      -999.00     0
    6   143.90      81.41       80.94       -999.00     1
    7   175.86      16.91       134.80      -999.00     0
    8   -999.00     162.17      125.95      -999.00     0
    9   143.90      81.41       80.94       -999.00     1
Run Code Online (Sandbox Code Playgroud)

并想要这样的输出:

For    K=3 (Folds)

When K=1
Training:
            MMC         MET_lep     MASS_Vis    Pt_H …
Run Code Online (Sandbox Code Playgroud)

python machine-learning data-analysis pandas data-science

0
推荐指数
1
解决办法
1万
查看次数