python2和python3实现在图片上加汉字的方法
作者:Nani_xiao 发布时间:2021-08-16 05:46:29
标签:python,图片,加汉字
python2和python3实现在图片上加汉字,最主要的区别还是内部编码方式不一样导致的,在代码上表现为些许的差别。理解了内部编码原理也就不会遇到这些问题了,以下代码是在WIN10系统上时测好用的。
Python2 在图片上加汉字代码实现
# -*- coding: cp936 -*-
import cv2
import numpy as np
from PIL import Image, ImageDraw, ImageFont
def ID_2_Word(txt):
tmp_ID = txt.split(':')[0]
value = txt.split(':')[-1]
'''
numbers = {
'DS041' : "Coolant TEMP ",
'DS048' : "RPM ",
'DS049' : "Speed ",
'DS098' : "Oil level ",
'DS123' : "Control Module Voltage"
}
'''
numbers = {
'DS041' : "冷却液温度",
'DS048' : "发动机转速",
'DS049' : "车速 ",
'DS098' : "燃油液位输入",
'DS123' : "控制模块电压"
}
word = numbers.get(tmp_ID, None)
result = str(word) + ':' + value
#print(result)
return result
def cv2ImgAddText(img, text, left, top, textColor=(0, 255, 0), textSize=20):
if (isinstance(img, np.ndarray)): #判断是否OpenCV图片类型
img = Image.fromarray(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))
draw = ImageDraw.Draw(img)
#fontText = ImageFont.truetype("font/simsun.ttc", textSize, encoding="utf-8")
fontText = ImageFont.truetype("font/simsun.ttc", textSize, encoding="gb2312") #cp936
draw.text((left, top), text, textColor, font=fontText)
return cv2.cvtColor(np.asarray(img), cv2.COLOR_RGB2BGR)
def layer1_show(img,data):
frame = cv2.resize(img, (1280, 720), interpolation=cv2.INTER_CUBIC)
font = ImageFont.truetype('font/simsun.ttc',24,encoding="utf-8")
OBD_string = data
y0, dy = 50, 25
for i, txt in enumerate(OBD_string.split(';')):
#word = txt
word = ID_2_Word(txt) #将OBD信号的ID转换为中文
word = unicode(word,'gbk')
#print(i, txt.split(':')[0])
y = y0+i*dy
frame = cv2ImgAddText(frame, word, 100, y, (255, 0, 0), 20)
cv2.imshow("layer_1", frame)
cv2.waitKey(0)
if __name__ == '__main__':
img = cv2.imread("map.png");
data = "DS041: 88;DS048: 800;DS049: 64;DS098: 0.00;DS123: 0.00"
layer1_show(img,data)
Python3 在图片上加汉字代码实现
import cv2
import numpy as np
from PIL import Image, ImageDraw, ImageFont
def ID_2_Word(txt):
tmp_ID = txt.split(':')[0]
value = txt.split(':')[-1]
'''
numbers = {
'DS041' : "Coolant TEMP ",
'DS048' : "RPM ",
'DS049' : "Speed ",
'DS098' : "Oil level ",
'DS123' : "Control Module Voltage"
}
'''
numbers = {
'DS041' : "冷却液温度",
'DS048' : "发动机转速",
'DS049' : "车速 ",
'DS098' : "燃油液位输入",
'DS123' : "控制模块电压"
}
word = numbers.get(tmp_ID, None)
result = str(word) + ':' + value
#print(result)
return result
def cv2ImgAddText(img, text, left, top, textColor=(0, 255, 0), textSize=20):
if (isinstance(img, np.ndarray)): #判断是否OpenCV图片类型
img = Image.fromarray(cv2.cvtColor(img, cv2.COLOR_BGR2RGB))
draw = ImageDraw.Draw(img)
#fontText = ImageFont.truetype("font/simsun.ttc", textSize, encoding="utf-8")
fontText = ImageFont.truetype("font/simsun.ttc", textSize, encoding="gb2312") #cp936
draw.text((left, top), text, textColor, font=fontText)
return cv2.cvtColor(np.asarray(img), cv2.COLOR_RGB2BGR)
def layer1_show(img,data):
frame = cv2.resize(img, (1280, 720), interpolation=cv2.INTER_CUBIC)
font = ImageFont.truetype('font/simsun.ttc',24,encoding="utf-8")
OBD_string = data
y0, dy = 50, 25
for i, txt in enumerate(OBD_string.split(';')):
#word = txt
word = ID_2_Word(txt) #将OBD信号的ID转换为中文
#word = unicode(word,'gbk')
y = y0+i*dy
frame = cv2ImgAddText(frame, word, 100, y, (255, 0, 0), 20)
cv2.imshow("layer_1", frame)
cv2.waitKey(0)
if __name__ == '__main__':
img = cv2.imread("map.png");
data = "DS041: 88;DS048: 800;DS049: 64;DS098: 0.00;DS123: 0.00"
layer1_show(img,data)
遇到的问题
python2中:UnicodeDecodeError: ‘ascii' codec can't decode byte 0xe8 in position 0: ordinal not in range(128)
这是因为这是因为默认的是utf-8编码格式
中文字符的Unicode编码0x0800-0xFFFF之间,(utf-8包含了部分汉字)
当你试图将该“中文字符”转成U码的utf-8时超出了其范筹
而GBK 规范收录了 ISO 10646.1 中的全部 CJK 汉字和符号,并有所补充,
所以解决方法是将utf-8改为gbk
word = unicode(word,'utf-8') 改为 word = unicode(word,'gbk')
总结
以上所述是小编给大家介绍的python2和python3实现在图片上加汉字的方法网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
来源:https://blog.csdn.net/xiao_lxl/article/details/97644624
0
投稿
猜你喜欢
- 我 们知道Express是一个基于NodeJS的非常优秀的服务端开发框架,本篇CSSer将提供express框架的route和route c
- 如果你过分信任 Access 2000数据库的密码保护,你可能会因此而蒙受损失。这是因为Access 2000的数据库级密码并不安全,相反它
- 实际工作经历中,免不了有时候需要连接数据库进行问题排查分析的场景,之前一直习惯通过 mysql -uxxx -hxxxx -P1234 ..
- 1 之前我们学习了列表,知道列表可以用来存储一组数据,可以增删改查,可以遍历2 之前我们学习了字典,知道字典可以用来存储键值对,与列表类似,
- 什么是探索性数据分析(EDA)?EDA 是数据分析下的一种现象,用于更好地理解数据方面,例如: – 数据的主要
- 调用很简单 Readkid.motion.tween(target,duration, vars)target: 要缓动的DOM对象dura
- 本文介绍一款工具 go-callvis,它能够将 Go 代码的调用关系可视化出来,并提供了可交互式的 web 服务。go get -u gi
- 一、场景说明在面试接口自动化时,经常会问,其他接口调用的前提条件是当前用户必须是登录状态,如何处理接口依赖?在此之前我们介绍过session
- 我们有下面一张PDF格式存储的表格,现在需要使用Python将它提取出来。使用Python提取表格数据需要使用pdfplumber模块,打开
- 在本文中,将详细介绍Playwright的文本框操作, 包括如何获得文本框的值, 以及向文本框中添加单行和多行文本。田辛老师将用网上的一个测
- 引言 性能是一个特征。您必须预先设计性能,否则您以后就得重写应用程序。就是说,有哪些好的策略可使 Active Server Pages (
- 前言ES6为Array增加了from函数用来将其他对象转换成数组。当然,其他对象也是有要求,也不是所有的,可以将两种对象转换成数组。1.部署
- 1.调整内存 sp_configure 'show advanced options',1 GO RECONFIGURE G
- 数学是优美的. 听上去有点奇怪? 当我第一次开始设计的时候,我确信如此。数学如此刻板乏味。你可能会惊讶的发现,最美观的设计,艺术作品,物体,
- 前言:又到每日分享Python小技巧的时光了,今天给大家分享的是Python接口常用封装函数。相信对于封装,大家都不陌生吧,今天就用四个小案
- 假设我们有一个非常简单的Post模型,它将是一个图像及其描述,from django.db import modelsclass Post(
- 本文实例讲述了Java连接各种数据库的方法。分享给大家供大家参考。具体如下://MySQL:  
- Django中的中间件是一个轻量级、底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入或输出。中间件的设计为开
- this 的定义表示当前执行代码的环境对象 因此可将 this 的剖析分为“全局环境” 和 “函数环境” 两种类型的环境对象全局环
- 1. 前言。1.1. 需求背景。 每天抓取的是同一份商品的数据,用来做趋势分析。要求每天都需要抓一份,也仅限抓取一份数据。但是整个