请教 使用 Tesseract 识别 图片文字,一直提示 ArgumentException: 路径的形式不合法。 大神请指教一下 谢谢

2021-11-17 08:59:59 +08:00
 rm0gang0rf
var path = Path.GetDirectoryName(Assembly.GetExecutingAssembly().CodeBase);
path = Path.Combine(path, "tessdata");
path = path.Replace("file:\\", "");
using (var engine = new TesseractEngine(path, "eng", EngineMode.Default))
{
using (var img = Pix.LoadFromFile("./0.png"))
{
using (var page = engine.Process(img))
{
return(page.GetText());

}
}
}
1665 次点击
所在节点    C#
6 条回复
sadfQED2
2021-11-17 09:17:28 +08:00
路径打印出来看一下,不要用相对路径,tessdata 库在 python 里面是是命令行调用二进制文件,不知道 c#是不是也这样
rm0gang0rf
2021-11-17 10:00:12 +08:00
@sadfQED2 好的 谢谢 这折腾一天了快~
rm0gang0rf
2021-11-17 11:01:34 +08:00
各种方法 绝对 相对 都试过了~~
coder001
2021-11-24 21:27:48 +08:00
把训练数据、Tesseract.dll 放到 exe 旁边

```csharp
new TesseractEngine(".", "chi_sim")
```

一直能正常使用,大概你还需要确认一下子文件夹 x86 、x64 里面的 dll 有没有正确放置

```
bin
│ chi_sim.traineddata
│ Tesseract.dll
│ TSR.exe
│ TSR.pdb

├─x64
│ leptonica-1.78.0.dll
│ tesseract41.dll

└─x86
leptonica-1.78.0.dll
tesseract41.dll
```
coder001
2021-11-24 21:31:36 +08:00
完整代码可以在咕狗搜 TesseractScreenReader 主域名是 topcl ,是个自己搭的 gogs ,怕被当 spam 就不贴出来了
rm0gang0rf
2021-11-25 09:44:23 +08:00
@coder001 谢谢 已经解决了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/815929

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX