1 Star 0 Fork 258

Wxl6415/书法体识别APP

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
util.py 1.64 KB
一键复制 编辑 原始数据 按行查看 历史
Wxl6415 提交于 2023-05-14 12:34 . 作业
# 引入必要的库
# TODO
import os
import yaml
import cv2
import numpy as np
import joblib
import time
import joblib
import skimage
# 获取 0_setting.yaml 中的键 key 对应的值 value
def get(key):
# TODO
with open("0_setting.yaml", "r",encoding='utf-8') as f:
config = yaml.safe_load(f) # config就自动包含了yaml文件中的所有字典信息
value = config[key]
return value
# 预处理图像, 把图像设置为指定大小之后,展平返回
def preprocess_image(file_name,new_size):
# 1. 读取图像灰度图
# TODO
# img_float = cv2.imread(file_name, cv2.IMREAD_GRAYSCALE).astype(np.float) # 只改变为浮点数
# img = cv2.imread(os.path.join(file_name), 0)
img = cv2.imdecode(np.fromfile(os.path.join(file_name),dtype=np.uint8),0)
img_float = skimage.img_as_float(img)#改变为归一化的浮点数
# 2. 调整图像大小为 new_size
# TODO
img_new_size = cv2.resize(img_float, new_size)
# 3. 将图像展平为一维数组
# TODO
img = img_new_size.reshape(-1)
return img
# 用joblib把叫做 name 的对象 obj 保存(序列化)到位置 loc
def dump(obj, name, loc):
start = time.time()
print(f"把{name}保存到{loc}")
# TODO 此处序列化对象
joblib.dump(obj, loc)
end = time.time()
print(f"保存完毕,文件位置:{loc}, 大小:{os.path.getsize(loc) / 1024 / 1024:.3f}M")
print(f"运行时间:{end - start:.3f}秒")
# 用joblib读取(反序列化)位置loc的对象obj,对象名为name
def load(name, loc):
print(f"从{loc}提取文件{name}")
#TODO 此处反序列化对象
obj = joblib.load(loc)
return obj
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/wxl6415/shufa_app.git
git@gitee.com:wxl6415/shufa_app.git
wxl6415
shufa_app
书法体识别APP
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385