我用 vue-service-cli 创建了一个项目。尝试使用 tesseract OCR 但我无法在本地和远程加载 lang.traineddata。我已经尝试了来自 tesseract.js repo 和其他许多方法的示例(它们有效),但没有结果。当我尝试加载它们时,我看到标准错误:
Error opening data file ./eng.traineddata
Please make sure the TESSDATA_PREFIX environment variable is set to your "tessdata" directory.
Failed loading language 'eng'
Tesseract couldn't load any languages!
AdaptedTemplates != nullptr:Error:Assert failed:in file /src/src/classify/adaptmatch.cpp, line 196
trap!
我怀疑这是 .asar 存档格式(来自vue-cli-plugin-electron-builder)的问题,该格式位于“/node_modules/electron/dist/resources/electron.asar”中。我可以从 ./public 加载文件,但我被读取的语言文件必须在进程目录中 - 我不知道这是不是真的。某些配置不能一起工作。
我的代码
const data = await Tesseract.recognize(
"https://tesseract.projectnaptha.com/img/eng_bw.png",
"eng",
{
logger: console.log,
corePath: window.location.origin + "/tesseract/tesseract-core.wasm.js",
workerPath: window.location.origin + "/tesseract/worker.min.js",
langPath: window.location.origin + "/tesseract/tessdata"
//or
langPath: path.join(__dirname, "tessdata")
}
我的依赖
"dependencies": {
"core-js": "^3.4.4",
"electron": "5.0.0",
"semantic-ui-css": "^2.4.1",
"tesseract.js": "2.0.2",
"vue": "^2.6.10",
"vue-class-component": "^7.0.2",
"vue-property-decorator": "^8.3.0",
"vue-router": "^3.1.3",
"vuex": "^3.1.2"
},
"devDependencies": {
"@vue/cli-plugin-babel": "^4.1.0",
"@vue/cli-plugin-eslint": "^4.1.0",
"@vue/cli-plugin-router": "^4.1.0",
"@vue/cli-plugin-typescript": "^4.1.0",
"@vue/cli-plugin-vuex": "^4.1.0",
"@vue/cli-service": "^4.1.0",
"@vue/eslint-config-prettier": "^5.0.0",
"@vue/eslint-config-typescript": "^4.0.0",
"eslint": "^5.16.0",
"eslint-plugin-prettier": "^3.1.1",
"eslint-plugin-vue": "^5.0.0",
"node-sass": "^4.12.0",
"prettier": "^1.19.1",
"pug": "^2.0.4",
"pug-plain-loader": "^1.0.0",
"sass-loader": "^8.0.0",
"typescript": "~3.5.3",
"vue-cli-plugin-electron-builder": "^1.4.4",
"vue-template-compiler": "^2.6.10"
}
编辑:我注意到https://github.com/auth0-blog/electron-vue项目与 Tesseract.js 配合得很好。该项目使用 Vue 但没有 vue-vli-service,这意味着它没有确认上述论点的 vue-cli-plugin-electron-builder。我仍在寻找使用 vue-cli 的解决方案