如何解决慢请求/响应 - 使用 App Inventor 的 Google OCR API
我正在使用 App Inventor 编写一个应用程序,该应用程序的目标是对从相机拍摄/从图库中选择的一些图像进行 OCR,并显示 OCR 内容。
我使用base64编码将图像转换为字符串,通过谷歌脚本发送到谷歌驱动器,通过谷歌脚本进行ocr并将结果返回给我的应用程序。
它有效,但对于每张图像(150-1000kB),处理大约需要 7-10 秒,因为我想在现场操作中处理 100 多张图像,处理时间对于实际使用来说太长了。
以下是我的 App Inventor Block
Display result from Google Script
以下是谷歌脚本
function doPost(e) {
var data = Utilities.base64Decode(e.parameters.data);
var blob = Utilities.newBlob(data,e.parameters.mimetype,e.parameters.filename);
//provide here a folder ID for the creation of the image file
var fileID = DriveApp.getFolderById('<Folder ID>').createFile(blob).getId();
if ( fileID !== "" ) {
try {
// Fetch the image from drive
var imageBlob = DriveApp.getFileById(fileID).getBlob();
var resource = { title: e.parameters.filename,mimeType: imageBlob.getContentType() };
// OCR on .jpg,.png,.gif,(or .pdf uploads)
var options = { ocr: true };
var docFile = Drive.Files.insert(resource,imageBlob,options);
var doc = DocumentApp.openById(docFile.id);
// Extract the text body of the Google Document
var text = doc.getBody().getText().replace("\n","");
// Send the documents to trash
Drive.Files.remove(docFile.id);
Drive.Files.remove(fileID);
status = text;
} catch (error) {
status = "ERROR with OCR: " + error.toString();
}
} else {
status = "ERROR with OCR: No image specified";
}
return ContentService.createtextoutput(status);
}```
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。