質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.06%

Python3でscrapyのインストールに失敗します。

解決済

回答 4

投稿

  • 評価
  • クリップ 1
  • VIEW 1,610

score 30

環境は
CentOS6系でPython3.5.3です。
pipでscrapyをインストールしようとすると下記エラーとなります。
gcc gcc-c++ kernel-devel libffi-devel python-devel openssl-devel libxslt-devel openssl pyOpenSSL
などを入れてみたり、色々検索して試してみたのですが一向に解決しないので、投稿いたしました。
全ては載せきれなかったので怪しそうな部分を載せます。
大変恐縮ですが、初心者にもわかりやすく解説して頂ければ幸いです。

    running egg_info
    writing src/cryptography.egg-info/PKG-INFO
    writing entry points to src/cryptography.egg-info/entry_points.txt
    writing requirements to src/cryptography.egg-info/requires.txt
    writing dependency_links to src/cryptography.egg-info/dependency_links.txt
    writing top-level names to src/cryptography.egg-info/top_level.txt
    reading manifest file 'src/cryptography.egg-info/SOURCES.txt'
    reading manifest template 'MANIFEST.in'
    no previously-included directories found matching 'docs/_build'
    warning: no previously-included files matching '*' found under directory 'vectors'
    writing manifest file 'src/cryptography.egg-info/SOURCES.txt'
    running build_ext
    generating cffi module 'build/temp.linux-x86_64-3.5/_padding.c'
    creating build/temp.linux-x86_64-3.5
    generating cffi module 'build/temp.linux-x86_64-3.5/_constant_time.c'
    generating cffi module 'build/temp.linux-x86_64-3.5/_openssl.c'
    building '_openssl' extension
    creating build/temp.linux-x86_64-3.5/build
    creating build/temp.linux-x86_64-3.5/build/temp.linux-x86_64-3.5
    gcc -pthread -Wsign-compare -DDYNAMIC_ANNOTATIONS_ENABLED=1 -DNDEBUG -O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions -fstack-protector --param=ssp-buffer-size=4 -m64 -mtune=generic -D_GNU_SOURCE -fPIC -fwrapv -fPIC -I/usr/include/python3.m -c build/temp.linux-x86_64-3.5/_openssl.c -o build/temp.linux-x86_64-3.5/build/temp.linux-x86_64-3.5/_openssl.o
    build/temp.linux-x86_64-3.5/_openssl.c:12:24: error: pyconfig.h: そのようなファイルやディレクトリはありません
    build/temp.linux-x86_64-3.5/_openssl.c:18:20: error: Python.h: そのようなファイルやディレクトリはありません
    build/temp.linux-x86_64-3.5/_openssl.c:363: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘*’ token
    build/temp.linux-x86_64-3.5/_openssl.c:713:22: error: pythread.h: そのようなファイルやディレクトリはありません
    build/temp.linux-x86_64-3.5/_openssl.c: In function ‘dev_urandom_fd’:
    build/temp.linux-x86_64-3.5/_openssl.c:2538: 警告: implicit declaration of function ‘fstat’
    build/temp.linux-x86_64-3.5/_openssl.c: トップレベル:
    build/temp.linux-x86_64-3.5/_openssl.c:3554: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘*’ token
    build/temp.linux-x86_64-3.5/_openssl.c: In function ‘_ssl_thread_locking_function’:
    build/temp.linux-x86_64-3.5/_openssl.c:3572: error: ‘_ssl_locks’ undeclared (first use in this function)
    build/temp.linux-x86_64-3.5/_openssl.c:3572: error: (Each undeclared identifier is reported only once
    build/temp.linux-x86_64-3.5/_openssl.c:3572: error: for each function it appears in.)
    build/temp.linux-x86_64-3.5/_openssl.c:3578: 警告: implicit declaration of function ‘PyThread_acquire_lock’
    build/temp.linux-x86_64-3.5/_openssl.c:3580: 警告: implicit declaration of function ‘PyThread_release_lock’
    build/temp.linux-x86_64-3.5/_openssl.c: In function ‘_setup_ssl_threads’:
    build/temp.linux-x86_64-3.5/_openssl.c:3587: error: ‘_ssl_locks’ undeclared (first use in this function)
    build/temp.linux-x86_64-3.5/_openssl.c:3589: 警告: implicit declaration of function ‘PyMem_New’
    build/temp.linux-x86_64-3.5/_openssl.c:3589: error: ‘PyThread_type_lock’ undeclared (first use in this function)
    build/temp.linux-x86_64-3.5/_openssl.c:3591: 警告: implicit declaration of function ‘PyErr_NoMemory’
    build/temp.linux-x86_64-3.5/_openssl.c:3596: 警告: implicit declaration of function ‘PyThread_allocate_lock’
    build/temp.linux-x86_64-3.5/_openssl.c:3600: 警告: implicit declaration of function ‘PyThread_free_lock’
    build/temp.linux-x86_64-3.5/_openssl.c:3602: 警告: implicit declaration of function ‘PyMem_Free’
    build/temp.linux-x86_64-3.5/_openssl.c: トップレベル:
    build/temp.linux-x86_64-3.5/_openssl.c:12998: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘*’ token
    build/temp.linux-x86_64-3.5/_openssl.c:13034: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘*’ token
    build/temp.linux-x86_64-3.5/_openssl.c:13058: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘*’ token
.....(上記の数字違いが数十行)
    build/temp.linux-x86_64-3.5/_openssl.c:70617: error: ‘_cffi_f_ASN1_IA5STRING_new’ undeclared here (not in a function)
    build/temp.linux-x86_64-3.5/_openssl.c:70618: error: ‘_cffi_f_ASN1_INTEGER_cmp’ undeclared here (not in a function)
    build/temp.linux-x86_64-3.5/_openssl.c:70619: error: ‘_cffi_f_ASN1_INTEGER_dup’ undeclared here (not in a function)
.....(上記の数字違いが数十行)
    build/temp.linux-x86_64-3.5/_openssl.c:73317: error: expected ‘=’, ‘,’, ‘;’, ‘asm’ or ‘__attribute__’ before ‘init_openssl’
    error: command 'gcc' failed with exit status 1

    ----------------------------------------
Command "/usr/bin/python3.5 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-2uh6etal/cryptography/setup.py';f=getattr(tokenize, 'open', open)(__file__);code=f.read().replace('\r\n', '\n');f.close();exec(compile(code, __file__, 'exec'))" install --record /tmp/pip-p1x27bcm-record/install-record.txt --single-version-externally-managed --compile" failed with error code 1 in /tmp/pip-build-uh6etal/cryptography/
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 4

checkベストアンサー

+1

yumで「python35u」をインストールしているのであれば、以下のパッケージを
利用するのではないでしょうか。

yum install python35u-devel

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/24 09:26

    ご回答ありがとうございます。
    一旦すべてremove後、python35u-develを含めて再インストールした結果、scrapyのインストールに成功しました。
    おそらく、removeしなくてもpython35u-develのインストールで成功したと思います。
    ありがとうございます。

    キャンセル

0

Python3.5.3 はどのようにインストールされていますか?

コンパイルしているとしたら、 yum 関連モジュールインストール後(ここでは、openssl-develだと思いますが)に、Python3.5.3 のリビルドが必要になります。

もう1度Pythonのコンパイルから行ってみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/23 23:11

    回答が遅くなり申し訳ありません。
    python3は、yumのiusリポジトリを利用してpython35uでインストールしました。
    一度、removeしてもう一度インストールということでよろしいでしょうか。

    キャンセル

  • 2017/03/24 09:59

    元々は、ソースからコンパイルしたものを使っていたのではないでしょうか?
    それを想定して、リビルドが必要というアドバイスをしました。

    キャンセル

  • 2017/03/24 10:25

    申し訳ありません。私の説明不足です。
    pythonとpipはyumにiusリポジトリを追加して、yumからインストールを行いました。

    キャンセル

0

エラーを見る限り、cryptography という Scrapy が依存してるライブラリのインストールに失敗しているようです。

http://stackoverflow.com/a/22210069/7724457

上記参考URLを見る限り必要な yumパッケージは gcc libffi-devel python-devel openssl-devel で、既にインストールされてるものの中に全て含まれているようです。

一応確認のために sudo yum list installed でちゃんとインストールされているか確認してみてください。もし何か足りないようであれば、下記の手順でもう一度 cryptography をインストールしてみてください。

$ sudo yum install gcc libffi-devel python-devel openssl-devel
$ pip cryptography

それでもダメなようであれば、 terapyon さんの仰るとおり、仮にソースからビルドしてPythonをインストールしているのであれば、リビルドが必要になるかもしれません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/24 00:15

    ご回答ありがとうございます。
    検証してみます。

    キャンセル

0

Failed to install Python Cryptography package with PIP and setup.pyによると、まずは以下を試してみるのもよいかと思います。
sudo yum install gcc libffi-devel python-devel openssl-devel
openssl-develのみでもよさそうですが。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/23 23:33

    確認不足でした。tell_kさんと同じ内容です。こちらの回答は無視してください。

    キャンセル

  • 2017/03/24 09:21

    ご回答ありがとうございます。了解しました。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.06%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る