2016-08-02 51 views
3

在我的电子程序,我已经通过NPM电子应用不能找到sqlite3的模块

npm install sqlite3 

安装sqlite3的,但一旦我尝试与数据库进行交互它不能找到数据库,这里是日志:

Uncaught Error: Cannot find module 'D:\play\electron-quick-start\node_modules\sqlite3\lib\binding\electron-v1.3-win32-x64\node_sqlite3.node'

这里是JS代码:

console.log('whooooo'); 

var sqlite3 = require('sqlite3').verbose(); 
var db = new sqlite3.Database('../db/info.db'); 

db.serialize(function() { 
    db.run("CREATE TABLE lorem (info TEXT)"); 

    var stmt = db.prepare("INSERT INTO lorem VALUES (?)"); 
    for (var i = 0; i < 10; i++) { 
     stmt.run("Ipsum " + i); 
    } 
    stmt.finalize(); 

    db.each("SELECT rowid AS id, info FROM lorem", function (err, row) { 
     console.log(row.id + ": " + row.info); 
    }); 
}); 
db.close(); 

我也尝试了这种方式:

npm install sqlite3 --build-from-source 

但它无法安装!

此外,我使用的是Python3。你如何安装一个模块来处理电子?

+0

你有这方面的任何解决方案? – Jay

回答

7

您必须使用基于电子的配置来构建此本机模块。

尝试:

2. npm run prepublish
3. node-gyp configure --module_name=node_sqlite3 --module_path=../lib/binding/electron-v1.3-win32-x64
4. node-gyp rebuild --target=1.3.1 --arch=x64 --target_platform=win32 --dist-url=https://atom.io/download/atom-shell --module_name=node_sqlite3 --module_path=../lib/binding/electron-v1.3-win32-x64

这是假设你有最新版本的电子。您可以更改配置以匹配您的电子版本。

+1

工作就像一个魅力,谢谢,记住如果你没有节点gyp,安装它之前做这个事情.. –

+1

它不适合我。任何解决这个错误?错误是:未捕获错误:找不到模块'path_to_project \ node_modules \ sqlite3 \ lib \ binding \ electron-v1.4-win32-ia32 \ node_sqlite3.node' – Jay

+0

http://stackoverflow.com/questions/41307807/i-am -getting-an-error-while-connecting-to-sqlite3-database是否有任何解决方案为这个 – Jay

12

首先:

npm install electron-rebuild

然后尝试了好几次:

./node_modules/.bin/electron-rebuild -w sqlite3 -p

+0

完美工作,如果在Windows上使用一些bash客户端(我使用git bash) – Ajay

0

1:包括重建的package.json文件,并安装NPM电子重建

{ 
    "name": "electron-quick-start", 
    "version": "1.0.0", 
    "description": "A minimal Electron application", 
    "main": "main.js", 
    "scripts": { 
    "start": "electron .", 
    "rebuild": "electron-rebuild -f -w sqlite3" 
    }, 
    "repository": "https://github.com/electron/electron-quick-start", 
    "keywords": [ 
    "Electron", 
    "quick", 
    "start", 
    "tutorial", 
    "demo" 
    ], 
    "author": "author", 
    "license": "CC0-1.0", 
    "devDependencies": { 
    "@types/file-saver": "0.0.1", 
    "electron": "1.7", 
    "electron-rebuild": "^1.6.0" 
    }, 
    "dependencies": { 
    "sqlite3": "^3.1.13" 
    } 
} 

2:in停止Python 2.7并将其路径添加到环境变量,例如C:\ Python27;

3:NPM安装,然后 NPM运行重建