Tesseract.js使用教程

Tesseract.js使用教程

1、安装 tesseract.js

npm install tesseract.js

2、在vue中引入tesseract.js

import Tesseract from 'tesseract.js'

3、调用recognize 方法

 Tesseract.recognize(
        url, //表示图片路径
        'chi_sim', //表示识别的目标语言
        ).then((d) => {
        //获取识别的文本
        console.log(d.data.text);
        this.msg = d.data.text;
        ocrStr.value = d.data.text
        })

4、整合vue的图片上传,完整代码

<template>
  <div>
    <el-button class="primary" @click="dialogVisible = true">图片识别</el-button>
    <div class="home" style="width:100%;height:500px">
    <el-dialog
        title="图片识别"
        :visible.sync="dialogVisible"
        width="30%"
       >
       <el-upload class="upload-demo"
       :auto-upload="false"
       :on-change="getImgUrl"
       :show-file-list="false"
       list-type="picture"
     >
        <el-button size="small" type="primary">点击上传</el-button>
        
        </el-upload>
        <el-image class="imgspan"  :src="imgUrl">
            <div slot="placeholder" class="image-slot">
                加载中<span class="dot">...</span>
            </div>
        </el-image>
       
        <el-button size="small" type="primary" @click="getTextByImg">识别图片信息</el-button>
   </el-dialog>
   <!-- 图片文字识别展示 -->
   <div>
        {{msg}}
        <hr>
        {{msg1}}
        <hr>
        <h3>每一列的数据:</h3>
         <ul>
            <li v-for="item in lines" :key="item">
                {{item.text.replace(/\s*/g,"")}}
            </li>
        </ul>
   </div>
  </div>
  </div>
</template>
<script>
// 1.引入tesseract.js

import Tesseract from 'tesseract.js';

export default {
  data () {
    return {
      dialogVisible:false,
      //显示上传的图片
      imgUrl:'',
      msg:'',
      msg1:'',
      lines:[]
    }
  },
 
  methods: {
    //点击获取图片路径
    getImgUrl(file){
     this.imgUrl = file.url
    },
    //识别图片内容
    getTextByImg(){
       // recognize方法的 第一个参数:图像,第二个:语种
        Tesseract.recognize(
        this.imgUrl,
        'chi_sim',
        //  { logger: m => console.log(m) }
        ).then((d) => {
        console.log(d);
        //获取每一列的文本信息
        this.lines = d.data.lines
        //获取权保护文本
        this.msg = d.data.text;
        //去除空格
        this.msg1 = d.data.text.replace(/\s*/g,"")
		//识别完成之后关闭模态框
        this.dialogVisible = false
        })
    }
   
  },

}
</script>
<style scoped>
    .imgspan{
        width: 100%;
        height: 200px;
       
    }
</style>

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Tesseract.js是一个基于Google开发的OCR引擎TesseractJavaScript库,可以在浏览器和Node.js环境中使用。React是一个由Facebook开发的用于构建用户界面的JavaScript库。在React应用程序中使用Tesseract.js可以使您的应用程序具有识别图像文本的能力。 以下是使用Tesseract.js在React应用程序中识别图像文本的详细步骤: 1. 首先,您需要安装Tesseract.js库。在您的React应用程序中,可以使用npm或yarn进行安装。使用以下命令进行安装: ``` npm install tesseract.js ``` 2. 接下来,您需要导入Tesseract.js库。您可以使用以下代码将其导入到React组件中: ```javascript import Tesseract from 'tesseract.js'; ``` 3. 然后,您需要创建一个函数,该函数将处理图像并将其传递给Tesseract.js以进行文本识别。您可以使用以下代码创建一个名为recognizeText的函数: ```javascript const recognizeText = async (image) => { const result = await Tesseract.recognize(image, 'eng'); return result.data.text; }; ``` 在上面的代码中,我们将image和'eng'作为参数传递给Tesseract.recognize()方法。image参数是要识别的图像,'eng'参数是要使用的语言。您可以根据需要更改这些参数。 4. 接下来,您需要在React组件中使用recognizeText函数。您可以在React组件的事件处理程序中使用它。例如,以下是一个名为handleImageUpload的事件处理程序,该处理程序将在选择图像时调用recognizeText函数并将结果存储在React状态中: ```javascript handleImageUpload = async (event) => { const file = event.target.files[0]; const reader = new FileReader(); reader.onloadend = async () => { const image = new Image(); image.src = reader.result; image.onload = async () => { const result = await recognizeText(image); this.setState({ text: result }); }; }; reader.readAsDataURL(file); }; ``` 在上面的代码中,我们使用FileReader读取选定的图像文件。然后,我们创建一个新的Image对象,并将其设置为从文件读取的结果。最后,我们在图像加载完成后调用recognizeText函数,并将结果存储在React状态中。 5. 最后,您可以在React组件的render方法中使用识别的文本。例如,以下是一个简单的render方法,该方法将识别的文本显示在屏幕上: ```javascript render() { return ( <div> <input type="file" onChange={this.handleImageUpload} /> <p>{this.state.text}</p> </div> ); } ``` 在上面的代码中,我们将handleImageUpload事件处理程序分配给文件上传输入。然后,我们使用this.state.text显示识别的文本。 这就是在React应用程序中使用Tesseract.js识别图像文本的基本步骤。您可以根据需要自定义这些代码以满足您的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值