解决:win10_x64 xgboost python安装失败错误问题

Python 2.6.7
Window10 X64
Git 2.10


前言

到处找啊找啊找啊找好用的分类器,抓到xgboost,听说表现比GBDT好,那我还玩什么GBDT。。。搞起


实测可用安装教程

windows 新版xgboost Python包安装教程 win10 64
亲测是可以完成安装的请大家可以看看,但是排版有点难受是不是,恩,我也觉的,哈哈,能安上就不错啦,还挑剔!还有一个也是可以成功安装的,记得他只是编译好了而已,还差最后一步,就是使用python setup.py install来安装xgboost而已,所以可以参考
@faithefeng--在python中安装xgBoost(win64+anaconda)
另外附赠官方安装教程,英语好可以看看


踩过的坑

如果你看到上面就安装成功了,那没必要往下看了,这里是实习司机翻车的历程(掩面哭)

1. 这个包我都下不下来,还tm怎么下一步?

我相信很多小伙伴下包的时候很麻烦是不是,各种限制,虽然不算是翻墙,但是网速有时候卡的一比啊,所以我直接把所有要用的包(git+wingw64)下好上传了,需要的可以直接下载Git-2.10.2-64-bit.exe 下载mingw64下载

2. 'cp','alias'等等 不是内部或外部命令,也不是可运行的程序

错了!!!这个,我真的折腾好久,因为一篇博客的误导,导致我一直在找我自己系统的问题,cp是linux的命令,复制文件用的,在win上一直是copy啊,然后一堆乱找,坑爹!这个命令不是在cmd上输入的!!!!这是在git bash上输入的!!!注意看清楚是在哪里输入命令,这次安装都不用cmd!!!这哥们也同样遇到这个问题

3. 不是git下来的包,咋的不能用呢?

以前我怕麻烦,直接下的zip,解压,安装setup.py完事,这次不行了,需要先编译啥的,所以推荐你最好是用git来获取github上最新的xgboost包,然后按照教程一步步走就可以了。所以事实上,你只需要git就可以了,当然还要个wingw64。

4. 使用Cygwin代替git bash怎么失败。

为了生命安全,请远离Cygwin,你的成功几率会上身百分之百。

5. no model name 'xgboost'

如果你按照@faithefeng--在python中安装xgBoost(win64+anaconda)来安装的,编译什么的一切正常,ok,你只是差最后一步,就是和普通的安装第三方包一样的步骤:

先进入xgboost路径下的python-package
然后cd python-package
再然后python setup.py install


测试xgboost栗子

为了检验是不是装完了,可以直接看看import xgboost可不可以用,为了显示其强大的分类能力,我以一个xgboost的多分类栗子来结束这次折腾半天的安装之旅,至于怎么调参就不是这篇要讨论的了。注意跑下列栗子你还需要下载一个数据集dermatology.data数据集下载,然后放在你的文件路径下或者自己改下路径

#! /usr/bin/python
import numpy as np
import xgboost as xgb

# label need to be 0 to num_class -1
data = np.loadtxt('./dermatology.data', delimiter=',',converters={33: lambda x:int(x == '?'), 34: lambda x:int(x)-1 } )
sz = data.shape

train = data[:int(sz[0] * 0.7), :]
test = data[int(sz[0] * 0.7):, :]

train_X = train[:,0:33]
train_Y = train[:, 34]


test_X = test[:,0:33]
test_Y = test[:, 34]

xg_train = xgb.DMatrix( train_X, label=train_Y)
xg_test = xgb.DMatrix(test_X, label=test_Y)
# setup parameters for xgboost
param = {}
# use softmax multi-class classification
param['objective'] = 'multi:softmax'
# scale weight of positive examples
param['eta'] = 0.1
param['max_depth'] = 6
param['silent'] = 1
param['nthread'] = 4
param['num_class'] = 6

watchlist = [ (xg_train,'train'), (xg_test, 'test') ]
num_round = 5
bst = xgb.train(param, xg_train, num_round, watchlist );
# get prediction
pred = bst.predict( xg_test );

print ('predicting, classification error=%f' % (sum( int(pred[i]) != test_Y[i] for i in range(len(test_Y))) / float(len(test_Y)) ))

# do the same thing again, but output probabilities
param['objective'] = 'multi:softprob'
bst = xgb.train(param, xg_train, num_round, watchlist );
# Note: this convention has been changed since xgboost-unity
# get prediction, this is in 1D array, need reshape to (ndata, nclass)
yprob = bst.predict( xg_test ).reshape( test_Y.shape[0], 6 )
ylabel = np.argmax(yprob, axis=1)

print ('predicting, classification error=%f' % (sum( int(ylabel[i]) != test_Y[i] for i in range(len(test_Y))) / float(len(test_Y)) ))

运算结果如下,说明你搞定了xgboost。。。。才怪嘞!这才安好包了而已!

[0] train-merror:0.011719   test-merror:0.127273
[1] train-merror:0.015625   test-merror:0.127273
[2] train-merror:0.011719   test-merror:0.109091
[3] train-merror:0.007812   test-merror:0.081818
[4] train-merror:0.007812   test-merror:0.090909
predicting, classification error=0.090909
[0] train-merror:0.011719   test-merror:0.127273
[1] train-merror:0.015625   test-merror:0.127273
[2] train-merror:0.011719   test-merror:0.109091
[3] train-merror:0.007812   test-merror:0.081818
[4] train-merror:0.007812   test-merror:0.090909
predicting, classification error=0.090909

BTW如果你是Ubuntu系统

恭喜你,中奖啦,直接在cmd下输入pip install xgboost就可以啦,亲测可用哦,但是在CentOS上不行,我也母鸡。


致谢

@ ychanmy--windows 新版xgboost Python包安装教程 win10 64
@faithefeng--在python中安装xgBoost(win64+anaconda)
@官方安装教程

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容