J'ai installé python-nltk sur Ubuntu Server 12.04 en utilisant apt-get.
Mais lorsque j'essaye de télécharger un corpus, j'obtiens l'erreur suivante:
$ python
Python 2.7.3 (default, Feb 27 2014, 19:58:35)
[GCC 4.6.3] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import nltk
>>> nltk.download('brown')
[nltk_data] Error loading brown: HTTP Error 401: Authorization
[nltk_data] Required
False
Me manque-t-il une configuration ou un package supplémentaire?
Le DEFAULT_URL
utilisé dans downloader.py
de la version fournie avec Ubuntu utilise toujours:
DEFAULT_URL = 'http://nltk.googlecode.com/svn/trunk/nltk_data/index.xml'
Mais le serveur de données actuel est:
DEFAULT_URL = "http://nltk.github.com/nltk_data/"
Vous pouvez bien sûr installer à partir de la source ou ... modifier votre version déjà installée pour qu'elle pointe vers le nouveau serveur comme ceci:
Sudo Perl -pi -e 's#DEFAULT_URL = .*#DEFAULT_URL = "http://nltk.github.com/nltk_data/"#' /usr/lib/python2.7/dist-packages/nltk/downloader.py
Vous pouvez ensuite installer le corpus "marron":
$ python
Python 2.7.6 (default, Mar 22 2014, 22:59:56)
[GCC 4.8.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> import nltk
>>> nltk.download('brown')
[nltk_data] Downloading package 'brown' to /home/sylvain/nltk_data...
[nltk_data] Unzipping corpora/brown.Zip.
True
>>> from nltk.corpus import brown
>>> brown.words()
['The', 'Fulton', 'County', 'Grand', 'Jury', 'said', ...]
>>>
Il est possible de résoudre ce problème sans changer le code source. Créez un téléchargeur personnalisé en python:
>>> dl = nltk.downloader.Downloader("http://nltk.github.com/nltk_data/")
alors vous ouvrez une boîte de dialogue graphique:
>>> dl.download()
Vérifiez que vous avez un accès en écriture au répertoire de téléchargement et téléchargez ce dont vous avez besoin.
pip install nltk --upgrade
Celui-ci met à jour le nltk et nltk.download()
fonctionne à nouveau.