【问题标题】:Tess4J: Invalid memory accessTess4J:无效的内存访问
【发布时间】:2013-11-22 13:52:27
【问题描述】:

我试图在我的项目中使用 Tess4J 从图像中提取文本。尝试运行 OCR 时出现以下错误: 线程“main”java.lang.Error 中的异常:内存访问无效

    try {
        File imageFile = new File("example4.jpg");
        Tesseract instance = Tesseract.getInstance(); // JNA Interface Mapping
        //Tesseract1 instance = new Tesseract1();
        String result = instance.doOCR(imageFile);
        System.out.println(result);
    } catch (Exception e) {
        e.printStackTrace();
    }   

【问题讨论】:

  • 本机代码中的错误。我建议你向 Tess4J 报告。
  • 发生在任何图像或仅此一个?

标签: java ocr tesseract


【解决方案1】:

当我设置解决问题的数据路径时,您可以设置我遇到同样问题的数据路径
试试这个

instance1.setDatapath("D://Hotel_project//Tess4J-1.2-src//Tess4J//tessdata");

【讨论】:

  • 项目在netbean中运行时完成,但运行可执行jar后出错
【解决方案2】:

您必须定义要使用的训练数据的数据路径。如果您不指定语言,它将假定它是 eng。

例如,如果您的项目路径是 PROJECT,而您的训练数据位于 PROJECT/data/tessdata/eng.traineddata

tess.setDatapath("data");
tess.setLanguage("eng");

请记住,“tessdata”不应位于您指定的路径中

【讨论】:

  • 如果我的文件夹结构是WEB-INF/classes/tessdata/eng.trainddata 怎么办?
【解决方案3】:

如果你在 32 位 JVM 上运行

请尝试使用 Tesseract1 instance = new Tesseract1();

而不是使用 Tesseract 实例 = Tesseract.getInstance();

【讨论】:

  • 我试试你的解决方案它不起作用。他们得到同样的错误
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-31
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多