1. ホーム
  2. python

[解決済み] Node.jsの依存性のためにWindowsでPythonを実行する

2022-01-30 23:39:20

質問

私はNode.jsのコードベースに入っていますが、NPM経由でいくつかの依存関係をダウンロードする必要があります。

を実行しようとすると npm install jquery このようなエラーが発生します。

Your environment has been set up for using Node.js 0.8.21 (x64) and NPM

C:\Users\Matt Cashatt>npm install jquery
npm http GET https://registry.npmjs.org/jquery
npm http 304 https://registry.npmjs.org/jquery
npm http GET https://registry.npmjs.org/jsdom
npm http GET https://registry.npmjs.org/xmlhttprequest
npm http GET https://registry.npmjs.org/htmlparser/1.7.6
npm http GET https://registry.npmjs.org/location/0.0.1
npm http GET https://registry.npmjs.org/navigator
npm http GET https://registry.npmjs.org/contextify
npm http 304 https://registry.npmjs.org/htmlparser/1.7.6
npm http 304 https://registry.npmjs.org/xmlhttprequest
npm http 304 https://registry.npmjs.org/location/0.0.1
npm http 304 https://registry.npmjs.org/navigator
npm http 304 https://registry.npmjs.org/jsdom
npm http 304 https://registry.npmjs.org/contextify
npm http GET https://registry.npmjs.org/bindings
npm http GET https://registry.npmjs.org/cssom
npm http GET https://registry.npmjs.org/cssstyle
npm http GET https://registry.npmjs.org/request
npm http 304 https://registry.npmjs.org/bindings

> [email protected] install C:\Users\Matt Cashatt\node_modules\jquery\node_module
s\contextify
> node-gyp rebuild


C:\Users\Matt Cashatt\node_modules\jquery\node_modules\contextify>node "C:\Progr
am Files\nodejs\node_modules\npm\bin\node-gyp-bin\\..\..\node_modules\node-gyp\b
in\node-gyp.js" rebuild
npm http 304 https://registry.npmjs.org/cssstyle
npm http 304 https://registry.npmjs.org/cssom
npm http 304 https://registry.npmjs.org/request
gyp ERR! configure error
gyp ERR! stack Error: Can't find Python executable "python", you can set the PYT
HON env variable.
gyp ERR! stack     at failNoPython (C:\Program Files\nodejs\node_modules\npm\nod
e_modules\node-gyp\lib\configure.js:113:14)
gyp ERR! stack     at C:\Program Files\nodejs\node_modules\npm\node_modules\node
-gyp\lib\configure.js:82:11
gyp ERR! stack     at Object.oncomplete (fs.js:297:15)
gyp ERR! System Windows_NT 6.1.7601
gyp ERR! command "node" "C:\\Program Files\\nodejs\\node_modules\\npm\\node_modu
les\\node-gyp\\bin\\node-gyp.js" "rebuild"
gyp ERR! cwd C:\Users\Matt Cashatt\node_modules\jquery\node_modules\contextify
gyp ERR! node -v v0.8.21
gyp ERR! node-gyp -v v0.8.4
gyp ERR! not ok
npm ERR! error rolling back Error: ENOTEMPTY, rmdir 'C:\Users\Matt Cashatt\node_
modules\jquery\node_modules\jsdom\node_modules\request\tests'
npm ERR! error rolling back  [email protected] { [Error: ENOTEMPTY, rmdir 'C:\Users\M
att Cashatt\node_modules\jquery\node_modules\jsdom\node_modules\request\tests']
npm ERR! error rolling back   errno: 53,
npm ERR! error rolling back   code: 'ENOTEMPTY',
npm ERR! error rolling back   path: 'C:\\Users\\Matt Cashatt\\node_modules\\jque
ry\\node_modules\\jsdom\\node_modules\\request\\tests' }
npm ERR! [email protected] install: `node-gyp rebuild`
npm ERR! `cmd "/c" "node-gyp rebuild"` failed with 1
npm ERR!
npm ERR! Failed at the [email protected] install script.
npm ERR! This is most likely a problem with the contextify package,
npm ERR! not with npm itself.
npm ERR! Tell the author that this fails on your system:
npm ERR!     node-gyp rebuild
npm ERR! You can get their info via:
npm ERR!     npm owner ls contextify
npm ERR! There is likely additional logging output above.

npm ERR! System Windows_NT 6.1.7601
npm ERR! command "C:\\Program Files\\nodejs\\\\node.exe" "C:\\Program Files\\nod
ejs\\node_modules\\npm\\bin\\npm-cli.js" "install" "jquery"
npm ERR! cwd C:\Users\Matt Cashatt
npm ERR! node -v v0.8.21
npm ERR! npm -v 1.2.11
npm ERR! code ELIFECYCLE
npm ERR! Error: ENOENT, lstat 'C:\Users\Matt Cashatt\node_modules\jquery\node_mo
dules\jsdom\node_modules\request\tests\test-pipes.js'
npm ERR! If you need help, you may report this log at:
npm ERR!     <http://github.com/isaacs/npm/issues>
npm ERR! or email it to:
npm ERR!     <[email protected]>

npm ERR! System Windows_NT 6.1.7601
npm ERR! command "C:\\Program Files\\nodejs\\\\node.exe" "C:\\Program Files\\nod
ejs\\node_modules\\npm\\bin\\npm-cli.js" "install" "jquery"
npm ERR! cwd C:\Users\Matt Cashatt
npm ERR! node -v v0.8.21
npm ERR! npm -v 1.2.11
npm ERR! path C:\Users\Matt Cashatt\node_modules\jquery\node_modules\jsdom\node_
modules\request\tests\test-pipes.js
npm ERR! fstream_path C:\Users\Matt Cashatt\node_modules\jquery\node_modules\jsd
om\node_modules\request\tests\test-pipes.js
npm ERR! fstream_type File
npm ERR! fstream_class FileWriter
npm ERR! code ENOENT
npm ERR! errno 34
npm ERR! fstream_stack C:\Program Files\nodejs\node_modules\npm\node_modules\fst
ream\lib\writer.js:284:26
npm ERR! fstream_stack Object.oncomplete (fs.js:297:15)
npm ERR!
npm ERR! Additional logging details can be found in:
npm ERR!     C:\Users\Matt Cashatt\npm-debug.log
npm ERR! not ok code 0

C:\Users\Matt Cashatt>

Pythonがインストールされていないことが原因で失敗しているようです。 さて、Pythonをインストールし、変数を設定し、再起動しましたが、まだエラーは続いています。

何が足りないのか、何か手がかりはないでしょうか?

解決方法は?

あなたの問題は、あなたが はしませんでした。 環境変数を設定します。

エラーにははっきりとこう書いてある。

gyp ERR! stack Error: Can't find Python executable "python", you can set the PYTHON env variable.

そして、コメントで、こんなことをしたと言っていますね。

set PYTHONPATH=%PYTHONPATH%;C:\My_python_lib

それはいいのですが、これでは PYTHON 変数を設定します。 PYTHONPATH という変数があります。


一方、ただ単に set コマンドは、現在の cmd セッションを使用します。その後に再起動すると、あなたが言ったように、全く新しい cmd セッションには、その変数が設定されていません。

環境変数を恒久的に設定する方法はいくつかあります。最も簡単なのはXPのシステムコントロールパネルで、Vistaではもちろん違いますし、7でも8でもまた違いますが、ググってみてください。

または、単に set の直前で npm コマンドを実行し、その間にリブートすることなく


コンフィグスクリプトが行おうとしていることと全く同じことを行うことで、正しいことを行ったかどうかをテストすることができます。を実行する前に npm を実行してみてください。 %PYTHON% . 正しく実行されていれば、Pythonインタプリタが表示されます(すぐに終了することができます)。もしエラーが出るようなら、それは正しいやり方ではありません。


これには2つの問題があります。

set PYTHON=%PYTHON%;D:\Python

まず最初に PYTHON から ;D:\Python . この余分なセミコロンは、セミコロンで区切られたパスのリストには問題ありません。 PATH または PYTHONPATH のような単一の値には適用されません。 PYTHON . また、同様に、既存の値に新しい値を追加することは、パスのリストに別のパスを追加したい場合に必要なことですが、単一の値に対しては必要ありません。つまり、あなたはただ set PYTHON=D:\Python .

2つ目 D:\Python はPythonインタプリタへのパスではありません。次のようなものです。 D:\Python\Python.exe または D:\Python\bin\Python.exe . 正しいパスを見つけ、それ自体で動作することを確認します (例: タイプ D:\Python\bin\Python.exe でPythonのインタプリタが出ることを確認してください)、そして変数をセットして使ってください。


だから

set PYTHON=D:\Python\bin\Python.exe

また、恒久的なものにしたい場合は、コントロールパネルで同等の操作を行ってください。