Ошибка: не удается найти модуль ‘@discordjs / opus’

#javascript #node.js #npm #discord.js #opus

#javascript #node.js #npm #discord.js #opus

Вопрос:

Каждый раз, когда я запускаю свой код распознавания речи discord, он подключается к сети, но как только он присоединяется к каналу, мой код показывает ошибку: не удается найти модуль «@discordjs / opus»

 Require stack:
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcutilloader.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusOpus.js  
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusindex.js 
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcindex.js      
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBasePlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBroadcastAudioPlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceVoiceBroadcast.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceClientVoiceManager.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientClient.js      
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotindex.js
Error: Cannot find module 'node-opus'
Require stack:
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcutilloader.js       
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusOpus.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusindex.js        
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBasePlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBroadcastAudioPlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceVoiceBroadcast.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceClientVoiceManager.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientClient.js      
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotindex.js
Error: Cannot find module 'opusscript'
Require stack:
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcutilloader.js       
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusOpus.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusindex.js        
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBasePlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBroadcastAudioPlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceVoiceBroadcast.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceClientVoiceManager.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientClient.js      
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotindex.js
2021-01-26T04:50:28.411Z :: discordClient message: Error: Error: Cannot find module '@discordjs/opus'
Require stack:
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcutilloader.js       
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusOpus.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusindex.js        
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBasePlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBroadcastAudioPlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceVoiceBroadcast.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceClientVoiceManager.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientClient.js      
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotindex.js
Error: Cannot find module 'node-opus'
Require stack:
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcutilloader.js       
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusOpus.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusindex.js        
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBasePlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBroadcastAudioPlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceVoiceBroadcast.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceClientVoiceManager.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientClient.js      
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotindex.js
Error: Cannot find module 'opusscript'
Require stack:
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcutilloader.js       
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusOpus.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcopusindex.js        
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesprism-mediasrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBasePlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceplayerBroadcastAudioPlayer.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceVoiceBroadcast.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientvoiceClientVoiceManager.js
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcclientClient.js      
- C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesdiscord.jssrcindex.js
- C:UsersSURYASHDesktopDiscordSpeechBotindex.js

 

Также при установке необходимых модулей / библиотек он показывает, что каким-то образом он не может установить discord / opus

 > @discordjs/opus@0.1.0 install C:UsersSURYASHDesktopDiscordSpeechBotnode_modules@discordjsopus
> node-pre-gyp install --fallback-to-build

node-pre-gyp WARN Using request for node-pre-gyp https download 
node-pre-gyp WARN Tried to download(404): https://github.com/discordjs/opus/releases/download/v0.1.0/opus-v0.1.0-node-v83-win32-x64.tar.gz 
node-pre-gyp WARN Pre-built binaries not found for @discordjs/opus@0.1.0 and node@14.15.4 (node-v83 ABI, unknown) (falling back to source compile with node-gyp) 
gyp ERR! find Python 
gyp ERR! find Python Python is not set from command line or npm configuration
gyp ERR! find Python Python is not set from environment variable PYTHON
gyp ERR! find Python checking if "python" can be used
gyp ERR! find Python - "python" is not in PATH or produced an error
gyp ERR! find Python checking if "python2" can be used
gyp ERR! find Python - "python2" is not in PATH or produced an error
gyp ERR! find Python checking if "python3" can be used
gyp ERR! find Python - "python3" is not in PATH or produced an error
gyp ERR! find Python checking if the py launcher can be used to find Python 2
gyp ERR! find Python - "py.exe" is not in PATH or produced an error
gyp ERR! find Python checking if Python is C:Python27python.exe
gyp ERR! find Python - "C:Python27python.exe" could not be run
gyp ERR! find Python checking if Python is C:Python37python.exe
gyp ERR! find Python - "C:Python37python.exe" could not be run
gyp ERR! find Python
gyp ERR! find Python **********************************************************
gyp ERR! find Python You need to install the latest version of Python.
gyp ERR! find Python Node-gyp should be able to find and use Python. If not,
gyp ERR! find Python you can try one of the following options:
gyp ERR! find Python - Use the switch --python="C:PathTopython.exe"
gyp ERR! find Python   (accepted by both node-gyp and npm)
gyp ERR! find Python - Set the environment variable PYTHON
gyp ERR! find Python - Set the npm configuration variable python:
gyp ERR! find Python   npm config set python "C:PathTopython.exe"
gyp ERR! find Python For more information consult the documentation at:
gyp ERR! find Python https://github.com/nodejs/node-gyp#installation
gyp ERR! find Python **********************************************************
gyp ERR! find Python
gyp ERR! configure error
gyp ERR! stack Error: Could not find any Python installation to use
gyp ERR! stack     at PythonFinder.fail (C:Program Filesnodejsnode_modulesnpmnode_modulesnode-gyplibfind-python.js:307:47)
gyp ERR! stack     at PythonFinder.runChecks (C:Program Filesnodejsnode_modulesnpmnode_modulesnode-gyplibfind-python.js:136:21)
gyp ERR! stack     at PythonFinder.<anonymous> (C:Program Filesnodejsnode_modulesnpmnode_modulesnode-gyplibfind-python.js:225:16)
gyp ERR! stack     at PythonFinder.execFileCallback (C:Program Filesnodejsnode_modulesnpmnode_modulesnode-gyplibfind-python.js:271:16)
gyp ERR! stack     at exithandler (child_process.js:315:5)
gyp ERR! stack     at ChildProcess.errorhandler (child_process.js:327:5)
gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:275:12)  
gyp ERR! stack     at onErrorNT (internal/child_process.js:465:16)
gyp ERR! stack     at processTicksAndRejections (internal/process/task_queues.js:80:21)       
gyp ERR! System Windows_NT 10.0.18363
gyp ERR! command "C:\Program Files\nodejs\node.exe" "C:\Program Files\nodejs\node_modules\npm\node_modules\node-gyp\bin\node-gyp.js" "configure" "--fallback-to-build" "--module=C:\Users\SURYASH\Desktop\DiscordSpeechBot\node_modules\@discordjs\opus\prebuild\node-v83-win32-x64\opus.node" "--module_name=opus" "--module_path=C:\Users\SURYASH\Desktop\DiscordSpeechBot\node_modules\@discordjs\opus\prebuild\node-v83-win32-x64" "--napi_version=7" "--node_abi_napi=napi" "--napi_build_version=0" "--node_napi_label=node-v83"
gyp ERR! cwd C:UsersSURYASHDesktopDiscordSpeechBotnode_modules@discordjsopus
gyp ERR! node -v v14.15.4
gyp ERR! node-gyp -v v5.1.0
gyp ERR! not ok
node-pre-gyp ERR! build error 
node-pre-gyp ERR! stack Error: Failed to execute 'C:Program Filesnodejsnode.exe C:Program 
Filesnodejsnode_modulesnpmnode_modulesnode-gypbinnode-gyp.js configure --fallback-to-build --module=C:UsersSURYASHDesktopDiscordSpeechBotnode_modules@discordjsopusprebuildnode-v83-win32-x64opus.node --module_name=opus --module_path=C:UsersSURYASHDesktopDiscordSpeechBotnode_modules@discordjsopusprebuildnode-v83-win32-x64 --napi_version=7 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v83' (1)
node-pre-gyp ERR! stack     at ChildProcess.<anonymous> (C:UsersSURYASHDesktopDiscordSpeechBotnode_modulesnode-pre-gyplibutilcompile.js:83:29)
node-pre-gyp ERR! stack     at ChildProcess.emit (events.js:315:20)
node-pre-gyp ERR! stack     at maybeClose (internal/child_process.js:1048:16)
node-pre-gyp ERR! stack     at Process.ChildProcess._handle.onexit (internal/child_process.js:288:5)
node-pre-gyp ERR! System Windows_NT 10.0.18363
node-pre-gyp ERR! command "C:\Program Files\nodejs\node.exe" "C:\Users\SURYASH\Desktop\DiscordSpeechBot\node_modules\node-pre-gyp\bin\node-pre-gyp" "install" "--fallback-to-build"
node-pre-gyp ERR! cwd C:UsersSURYASHDesktopDiscordSpeechBotnode_modules@discordjsopus  
node-pre-gyp ERR! node -v v14.15.4
node-pre-gyp ERR! node-pre-gyp -v v0.14.0
node-pre-gyp ERR! not ok
Failed to execute 'C:Program Filesnodejsnode.exe C:Program Filesnodejsnode_modulesnpmnode_modulesnode-gypbinnode-gyp.js configure --fallback-to-build --module=C:UsersSURYASHDesktopDiscordSpeechBotnode_modules@discordjsopusprebuildnode-v83-win32-x64opus.node --module_name=opus --module_path=C:UsersSURYASHDesktopDiscordSpeechBotnode_modules@discordjsopusprebuildnode-v83-win32-x64 --napi_version=7 --node_abi_napi=napi --napi_build_version=0 --node_napi_label=node-v83' (1)
npm ERR! code ELIFECYCLE
npm ERR! errno 1
npm ERR! @discordjs/opus@0.1.0 install: `node-pre-gyp install --fallback-to-build`
npm ERR! Exit status 1
npm ERR!
npm ERR! Failed at the @discordjs/opus@0.1.0 install script.
npm ERR! This is probably not a problem with npm. There is likely additional logging output above.

npm ERR! A complete log of this run can be found in:
npm ERR!     C:UsersSURYASHAppDataRoamingnpm-cache_logs2021-01-26T04_57_11_574Z-debug.log
 

Итак, в конечном итоге моему коду бота требуется модуль opus, и каким-то образом он не может его установить.

Комментарии:

1. Установите Python и повторите попытку.

2. @discordjs/opus это только одноранговая зависимость этого prism-media пакета, поэтому он не устанавливается автоматически (по крайней мере, до npm @ 7). Вы не забыли добавить его в качестве dep.?

Ответ №1:

сначала вам нужно установить python, после этого запустите это (admin powershell):

 npm install -g windows-build-tools
 

если эта команда не устраняет вашу проблему (проблема с узлом-gyp), чем

 # before installing node-gyp on windows
    npm install --global --production windows-build-tools
    
    # install node-gyp globally
    npm install -g node-gyp
 

Ответ №2:

Попробуйте это:

 npm install discordjs/opus
 

У меня была та же проблема «Ошибка: не удается найти модуль ‘@discordjs / opus'» при попытке заставить моего discord js-бота воспроизвести файл .mp3, когда определенный пользователь был говорящим

Понял это решение, посмотрев это видео. youtube.com/watch?v=WXohhIJ1-f4

Если вы не хотите переходить по ссылке, просто найдите «Как воспроизводить аудио в голосовом канале discord js» на YouTube!

Комментарии:

1. Полезно опубликовать решение, а не ссылаться на внешнее решение.

Ответ №3:

Попробуйте установить это: npm install --global windows-build-tools с помощью powershell администратора. windows-build-tools устанавливает с ним python.

Ответ №4:

откройте powershell (admin) и введите:

 npm install -g windows-build-tools
 

перед установкой node-gyp в Windows
npm установите —global —production windows-build-tools

установить узел-gyp глобально npm install -g node-gyp

Ответ №5:

Сначала установите python из https://www.python.org/downloads /. Это, по-видимому, основная проблема при установке, обязательно выберите Add python to path

как добавить python в path

Закройте терминал, снова откройте его, затем повторите попытку.

Если он по-прежнему не работает, откройте Windows power-shell от имени администратора и введите npm i -g windows-build-tools

Закройте терминал, снова откройте и попробуйте загрузить пакеты снова