# 1.3.4 tesserocr的安装
## 1.相关链接 {#2-相关链接}
* Tesserocr GitHub:[https://github.com/sirfz/tesserocr](https://github.com/sirfz/tesserocr)
* Tesserocr PyPi:[https://pypi.python.org/pypi/tesserocr](https://pypi.python.org/pypi/tesserocr)
* Tesseract下载地址:[http://digi.bib.uni-mannheim.de/tesseract](http://digi.bib.uni-mannheim.de/tesseract)
* Tesseract GitHub:[https://github.com/tesseract-ocr/tesseract](https://github.com/tesseract-ocr/tesseract)
* Tesseract 语言包:[https://github.com/tesseract-ocr/tessdata](https://github.com/tesseract-ocr/tessdata)
* Tesseract 文档:[https://github.com/tesseract-ocr/tesseract/wiki/Documentation](https://github.com/tesseract-ocr/tesseract/wiki/Documentation)
* Tesseract wheel:[https://github.com/simonflueckiger/tesserocr-windows\_build/releases](https://github.com/simonflueckiger/tesserocr-windows_build/releases)
## 2.windows下安装
![](https://box.kancloud.cn/16ba6d8277e18fa69acb972b21f21540_818x802.png)
其中文件名中带有 dev 的为开发版本,不带 dev 的为稳定版本,可以选择下载不带 dev 的最新版本,例如可以选择下载 tesseract-ocr-setup-3.05.01.exe。
接下来安装Tesserocr,直接使用pip 安装
```text
pip3 install tesserocr pillow
```
如果tesserocr安装报错
需要使用whl安装,并且需要安装Microsoft Visual C++ 14.0.exe
[下载地址](https://pan.baidu.com/s/1lL3WVCE2T-4zQJbjloP6-w)
```text
首先切换到有whl的目录
然后通过pip安装
pip install tesserocr-2.2.2-cp36-cp36m-win_amd64.whl
在这之前需要安装Microsoft Visual C++ 14.0.exe
```
## 3.Linux下的安装 {#4-linux下的安装}
对于 Linux 来说,不同系统已经有了不同的发行包了,它可能叫做 tesseract-ocr 或者 tesseract,直接用对应的命令安装即可。
### Ubuntu、Debian、Deepin {#ubuntu、debian、deepin}
安装命令如下:
```text
sudo apt-get install -y tesseract-ocr libtesseract-dev libleptonica-dev
```
### CentOS、RedHat {#centos、redhat}
安装命令如下:
```text
yum install -y tesseract
```
不同发行版本运行如上命令即可完成 Tesseract 的安装。
安装完成之后便可以调用 tesseract 命令了。
我们查看一下其支持的语言:
```text
tesseract --list-langs
```
运行结果示例:
```text
List of available languages (3):
eng
osd
equ
```
结果显示其只支持几种语言,如果我们想要安装多国语言还需要安装语言包,官方叫做 tessdata。
tessdata 的下载链接为:[https://github.com/tesseract-ocr/tessdata](https://github.com/tesseract-ocr/tessdata)。
利用 Git 命令将其下载下来并迁移到相关目录即可,不同的版本迁移命令如下:
### Ubuntu、Debian、Deepin {#ubuntu、debian、deepin}
```text
git clone https://github.com/tesseract-ocr/tessdata.git
sudo mv tessdata/* /usr/share/tesseract-ocr/tessdata
```
### CentOS、RedHat {#centos、redhat}
```text
git clone https://github.com/tesseract-ocr/tessdata.git
sudo mv tessdata/* /usr/share/tesseract/tessdata
```
这样就可以将下载下来的语言包全部安装了。
这时我们重新运行列出所有语言的命令:
```text
tesseract --list-langs
```
结果如下:
```text
List of available languages (107):
afr
amh
ara
asm
aze
aze_cyrl
bel
ben
bod
bos
bul
cat
ceb
ces
chi_sim
chi_tra
...
```
即可发现其列出的语言就多了非常多,比如 chi\_sim 就代表简体中文,这就证明语言包安装成功了。
接下来再安装 Tesserocr 即可,直接使用 Pip 安装:
```text
pip3 install tesserocr pillow
```
## 4. Mac下的安装 {#5-mac下的安装}
Mac 下首先使用 Homebrew 安装 Imagemagick 和 Tesseract 库:
```text
brew install imagemagick
brew install tesseract --all-languages
```
接下来再安装 Tesserocr 即可:
```text
pip3 install tesserocr pillow
```
这样便完成了 Tesserocr 的安装。
## 5.验证安装
分别测试Tesseract 和 Tesserocr
[测试图片](https://raw.githubusercontent.com/Python3WebSpider/TestTess/master/image.png):
![](https://box.kancloud.cn/b95c063e6f856598a1e2e477e97463b5_608x110.png)
用Tesseract 命令行测试,命令如下:
```text
tesseract image.png result -l eng && type result.txt
```
运行结果:
```text
Tesseract Open Source OCR Engine v3.05.01 with Leptonica
Python3WebSpider
```
需要注意:
* 需要将Tesseract-OCR目录配置到环境变量中
* 需要将Tesseract-OCR目录下的tessdata目录配置到环境变量中![](https://box.kancloud.cn/718831ebfcb7aedd9b03a28edf519fd5_837x178.png)
tesseract 命令参数讲解:
第一个参数为图片名称,第二个参数 result 为结果保存的目标文件名称,-l 指定使用的语言包,在此使用 eng 英文,然后再用 type命令将结果输出。
然后利用python代码进行测试,需要借助Tesserocr库,测试代码如下:
```text
import tesserocr
from PIL import Image
image = Image.open("D:/image.png")
print(tesserocr.image_to_text(image))
```
如果报错,错误方式如下:
![](https://box.kancloud.cn/7dfde8da64cafd5abde2f6f3828503e3_667x91.png)
需要将Tesseract-OCR目录下的tessdata目录拷贝到python36目录下
这时重新运行就会成功
![](https://box.kancloud.cn/6abd6d7b1b81d481578fef7ec791da39_539x84.png)
在这里首先利用 Image 读取了图片文件,然后调用了 tesserocr 的 image\_to\_text\(\) 方法,再将将其识别结果输出。
运行结果:
```text
Python3WebSpider
```
另外我们还可以直接调用 file\_to\_text\(\) 方法,也可以达到同样的效果:
```text
import tesserocr
print(tesserocr.file_to_text("D:\image.png"))
```
运行结果:
```text
Python3WebSpider
```
如果成功输出结果,则证明Tesseract和Tesserocr都已经安装成功
### 6.pytesseract库
pytesseract库和tesserocr库的效果一样,都可以识别图片,都是用的Tesseract-OCR来进行识别图片的,如果安装不成功就不要纠结tesserocr库了
```
>>> import pytesseract
>>> from PIL import Image
>>>
>>> image = Image.open('image.png')
>>> code = pytesseract.image_to_string(image)
>>> print(code)
Python3WebSpider
```
- 介绍
- 1.开发环境配置
- 1.1 python3的安装
- 1.1.1 windows下的安装
- 1.1.2 Linux下的安装
- 1.1.3 Mac下的安装
- 1.2 请求库的安装
- 1.2.1 requests的安装
- 1.2.2 selenium的安装
- 1.2.3 ChromeDriver的安装
- 1.2.4 GeckoDriver 的安装
- 1.2.5 PhantomJS的安装
- 1.2.6 aiohttp的安装
- 1.3 解析库的安装
- 1.3.1 lxml的安装
- 1.3.2 Beautiful Soup的安装
- 1.3.3 pyquery的安装
- 1.3.4 tesserocr的安装
- 1.4 数据库的安装
- 1.4.1 MySQL的安装
- 1.4.2 MongoDB的安装
- 1.4.3 Redis的安装
- 1.5 存储库的安装
- 1.5.1 PyMySQL的安装
- 1.5.2 PyMongo的安装
- 1.5.3 redis-py的安装
- 1.5.4 RedisDump的安装
- 1.6 Web库的安装
- 1.6.1 Flask的安装
- 1.6.2 Tornado的安装
- 1.7 App爬取相关库的安装
- 1.7.1 Charles的安装
- 1.7.2 mitmproxy的安装
- 1.7.3 Appium的安装
- 1.8 爬虫框架的安装
- 1.8.1 pyspider的安装
- 1.8.2 Scrapy的安装
- 1.8.3 Scrapy-Splash的安装
- 1.8.4 ScrapyRedis的安装
- 1.9 布署相关库的安装
- 1.9.1 Docker的安装
- 1.9.2 Scrapyd的安装
- 1.9.3 ScrapydClient的安装
- 1.9.4 ScrapydAPI的安装
- 1.9.5 Scrapyrt的安装
- 1.9.6-Gerapy的安装
- 2.爬虫基础
- 2.1 HTTP 基本原理
- 2.1.1 URI和URL
- 2.1.2 超文本
- 2.1.3 HTTP和HTTPS
- 2.1.4 HTTP请求过程
- 2.1.5 请求
- 2.1.6 响应
- 2.2 网页基础
- 2.2.1网页的组成
- 2.2.2 网页的结构
- 2.2.3 节点树及节点间的关系
- 2.2.4 选择器
- 2.3 爬虫的基本原理
- 2.3.1 爬虫概述
- 2.3.2 能抓怎样的数据
- 2.3.3 javascript渲染的页面
- 2.4 会话和Cookies
- 2.4.1 静态网页和动态网页
- 2.4.2 无状态HTTP
- 2.4.3 常见误区
- 2.5 代理的基本原理
- 2.5.1 基本原理
- 2.5.2 代理的作用
- 2.5.3 爬虫代理
- 2.5.4 代理分类
- 2.5.5 常见代理设置
- 3.基本库使用
- 3.1 使用urllib
- 3.1.1 发送请求
- 3.1.2 处理异常
- 3.1.3 解析链接
- 3.1.4 分析Robots协议
- 3.2 使用requests
- 3.2.1 基本用法
- 3.2.2 高级用法
- 3.3 正则表达式
- 3.4 抓取猫眼电影排行
- 4.解析库的使用
- 4.1 使用xpath
- 4.2 使用Beautiful Soup
- 4.3 使用pyquery
- 5.数据存储
- 5.1 文件存储
- 5.1.1 TXT 文件存储
- 5.1.2 JSON文件存储
- 5.1.3 CSV文件存储
- 5.2 关系型数据库存储
- 5.2.1 MySQL的存储
- 5.3 非关系数据库存储
- 5.3.1 MongoDB存储
- 5.3.2 Redis存储
- 6.Ajax数据爬取
- 6.1 什么是Ajax
- 6.2 Ajax分析方法
- 6.3 Ajax结果提取
- 6.4 分析Ajax爬取今日头条街拍美图
- 7.动态渲染页面爬取
- 7.1 Selenium的使用
- 7.2 Splash的使用
- 7.3 Splash负载均衡配置
- 7.4 使用selenium爬取淘宝商品
- 8.验证码的识别
- 8.1 图形验证码的识别
- 8.2 极验滑动验证码的识别
- 8.3 点触验证码的识别
- 8.4微博宫格验证码的识别
- 9.代理的使用
- 9.1 代理的设置
- 9.2 代理池的维护
- 9.3 付费代理的使用
- 9.4 ADSL拨号代理
- 9.5 使用代理爬取微信公总号文章
- 10.模拟登录
- 10.1 模拟登陆并爬去GitHub
- 10.2 Cookies池的搭建
- 11.App的爬取
- 11.1 Charles的使用
- 11.2 mitmproxy的使用
- 11.3 mitmdump“得到”App电子书信息
- 11.4 Appium的基本使用
- 11.5 Appnium爬取微信朋友圈
- 11.6 Appium+mitmdump爬取京东商品
- 12.pyspider框架的使用
- 12.1 pyspider框架介绍
- 12.2 pyspider的基本使用
- 12.3 pyspider用法详解
- 13.Scrapy框架的使用
- 13.1 scrapy框架介绍
- 13.2 入门
- 13.3 selector的用法
- 13.4 spider的用法
- 13.5 Downloader Middleware的用法
- 13.6 Spider Middleware的用法
- 13.7 Item Pipeline的用法
- 13.8 Scrapy对接Selenium
- 13.9 Scrapy对接Splash
- 13.10 Scrapy通用爬虫
- 13.11 Scrapyrt的使用
- 13.12 Scrapy对接Docker
- 13.13 Scrapy爬取新浪微博
- 14.分布式爬虫
- 14.1 分布式爬虫原理
- 14.2 Scrapy-Redis源码解析
- 14.3 Scrapy分布式实现
- 14.4 Bloom Filter的对接
- 15.分布式爬虫的部署
- 15.1 Scrapyd分布式部署
- 15.2 Scrapyd-Client的使用
- 15.3 Scrapyd对接Docker
- 15.4 Scrapyd批量部署
- 15.5 Gerapy分布式管理
- 微信公总号文章实战
- 源码
- other