react+Tesseract.js实现前端拍照获取/选择文件等文字识别OCR

需求背景

在开发过程中可能会存在用户上传一张图片后下方需要自己识别出来文字数字等信息,有的时候会通过后端来识别后返回,但是也会存在纯前端去识别的情况,这个时候就需要使用到Tesseract.js这个库了 附Tesseract.js官方(https://github.com/naptha/tesseract.js)

实现过程

主要的实现代码部分和这部分的简易效果图

javascript 复制代码
import {createWorker} from 'tesseract.js';

const worker = await createWorker();
await worker.loadLanguage('chi_sim');
await worker.initialize('chi_sim');
const { data: { text } } = await worker.recognize(myImage);
console.log(text);
await worker.terminate();

下方是一个简单的完整实现案例 ⬇

npm install tesseract.js

  1. createWorker创建worker实例。

  2. 调用worker.loadLanguage('chi_sim')。

  3. 调用worker.initialize('chi_sim')。

  4. 然后调用recognize方法进行识别。

javascript 复制代码
import React, { useState, useEffect } from 'react';
import { createWorker } from 'tesseract.js';

const OCRComponent = () => {
  const [image, setImage] = useState(null);
  const [text, setText] = useState('');
  const [progress, setProgress] = useState(0);
  const [error, setError] = useState('');
  const [worker, setWorker] = useState(null);

  // 初始化 Worker
  useEffect(() => {
    const initializeWorker = async () => {
      const newWorker = await createWorker();
      setWorker(newWorker);
    };
    initializeWorker();
    return () => {
      if (worker) {
        worker.terminate();
      }
    };
  }, []);

  // 处理图片上传
  const handleImageUpload = (e) => {
    const file = e.target.files[0];
    if (file) {
      const reader = new FileReader();
      reader.onloadend = () => {
        setImage(reader.result);
      };
      reader.readAsDataURL(file);
      setText('');
      setError('');
    }
  };

  // 执行 OCR 识别
  const recognizeText = async () => {
    if (!worker || !image) return;

    try {
      //chi_sim代表的是简体中文包  eng是英文  需要识别其他语言的话可以官网去看下对应的名称
      await worker.loadLanguage('chi_sim');
      await worker.initialize('chi_sim');
      const { data: { text } } = await worker.recognize(image, {
        logger: (m) => {
          if (m.status === 'recognizing text') {
            setProgress(Math.round(m.progress * 100));
          }
        }
      });
      setText(text);
    } catch (err) {
      setError('识别失败,请重试或更换图片。');
      console.error(err);
    } finally {
      await worker.terminate();
    }
  };

  return (
    <div>
      <h1>中文 OCR 文字识别</h1>
      
      {/* 文件上传 */}
      <input type="file" accept="image/*" onChange={handleImageUpload} />
      
      {/* 图片预览 */}
      {image && (
        <div>
          <h3>图片预览</h3>
          <img src={image} alt="预览" style={{ maxWidth: '100%', height: 'auto' }} />
        </div>
      )}

      {/* 识别按钮及进度 */}
      {image && (
        <div>
          <button onClick={recognizeText} disabled={progress > 0}>
            {progress > 0 ? `识别中... ${progress}%` : '开始识别'}
          </button>
        </div>
      )}

      {/* 显示结果 */}
      {text && (
        <div>
          <h3>识别结果</h3>
          <pre style={{ whiteSpace: 'pre-wrap' }}>{text}</pre>
        </div>
      )}

      {/* 错误提示 */}
      {error && <p style={{ color: 'red' }}>{error}</p>}
    </div>
  );
};

export default OCRComponent;
相关推荐
天天向上10246 分钟前
Vue 配置打包后可编辑的变量
前端·javascript·vue.js
芬兰y22 分钟前
VUE 带有搜索功能的穿梭框(简单demo)
前端·javascript·vue.js
好果不榨汁29 分钟前
qiankun 路由选择不同模式如何书写不同的配置
前端·vue.js
小蜜蜂dry29 分钟前
Fetch 笔记
前端·javascript
拾光拾趣录30 分钟前
列表分页中的快速翻页竞态问题
前端·javascript
小old弟31 分钟前
vue3,你看setup设计详解,也是个人才
前端
Lefan35 分钟前
一文了解什么是Dart
前端·flutter·dart
Patrick_Wilson40 分钟前
青苔漫染待客迟
前端·设计模式·架构
vvilkim42 分钟前
Nuxt.js 全面测试指南:从单元测试到E2E测试
开发语言·javascript·ecmascript
写不出来就跑路1 小时前
基于 Vue 3 的智能聊天界面实现:从 UI 到流式响应全解析
前端·vue.js·ui