精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何使用Python構建一個文檔掃描器?

譯文
開發 前端
結合使用多個適當的庫,您就可以構建一個小型應用程序對文檔進行數字化處理。您的程序將以物理文檔的圖像作為輸入,對其運用幾種圖像處理技術,即可輸出輸入的掃描版。

?譯者 | 布加迪

審校 | 孫淑娟

您可能想要對文檔進行數字化處理,以節省物理空間或創建備份。無論怎樣,編寫一個程序將紙質文件的照片轉換成準格式正是Python所擅長的任務。

結合使用多個適當的庫,您就可以構建一個小型應用程序對文檔進行數字化處理。您的程序將以物理文檔的圖像作為輸入,對其運用幾種圖像處理技術,即可輸出輸入的掃描版。

1、準備好環境

首先您應該熟悉Python的基礎知識,還需要了解如何使用NumPy Python庫。

打開任何Python IDE,創建兩個Python文件。將一個命名為main.py,將另一個命名為transform.py。然后在終端上執行以下命令,安裝所需的庫。

pip install OpenCV-Python imutils scikit-image NumPy

您將使用OpenCV-Python獲取圖像輸入并進行一些圖像處理,使用Imutils來調整輸入和輸出圖像的大小,并使用scikit-image對圖像施加閾值。NumPy將幫助您處理數組。

圖片

等待安裝完成,并等待IDE更新項目骨干內容。骨干內容更新完成后,您就可以開始編程了。完整的源代碼可以在GitHub代碼庫中找到。

2、導入已安裝的庫

打開main.py文件,導入所安裝的庫。這將使您能夠在必要時調用和使用它們的函數。

import cv2
import imutils
from skimage.filters import threshold_local
from transform import perspective_transform

忽略perspective_transform方面拋出的錯誤。您完成處理transform.py文件的工作后,錯誤會消失。

3、獲取并調整輸入的大小

為想要掃描的文檔拍攝一張清晰的圖像。確保文檔的四個角及其內容都可見。將圖像復制到存儲程序文件的同一個文件夾中。

圖片

將輸入圖像路徑傳遞給OpenCV。制作原始圖像的副本,因為您在透視轉換期間需要它。將原始圖像的高度除以您想要調整到的高度。這將保持縱橫比。最后,輸出調整后的圖像。

# Passing the image path
original_img = cv2.imread('sample.jpg')
copy = original_img.copy()

# The resized height in hundreds
ratio = original_img.shape[0] / 500.0
img_resize = imutils.resize(original_img, height=500)

# Displaying output
cv2.imshow('Resized image', img_resize)

# Waiting for the user to press any key
cv2.waitKey(0)

上述代碼的輸出如下:

圖片

現在您已經將原始圖像的高度調整為500像素。

4、將調整后的圖像轉換為灰度圖像

將調整后的RGB圖像轉換為灰度圖像。大多數圖像處理庫只處理灰度圖像,因為它們更容易處理。

gray_image = cv2.cvtColor(img_resize, cv2.COLOR_BGR2GRAY)
cv2.imshow('Grayed Image', gray_image)
cv2.waitKey(0)

注意原始圖像和灰度圖像之間的區別。

圖片

IDE上顯示灰色映像的程序輸出

彩色桌變成了黑白桌。

5、運用邊緣檢測器

對灰度圖像運用高斯模糊濾鏡以去除噪聲。然后調用OpenCV canny函數來檢測圖像中存在的邊緣。

blurred_image = cv2.GaussianBlur(gray_image, (5, 5), 0)
edged_img = cv2.Canny(blurred_image, 75, 200)
cv2.imshow('Image edges', edged_img)
cv2.waitKey(0)

邊緣在輸出上是可見的。

圖片

您將處理的邊緣是文檔的邊緣。

6、尋找最大的輪廓

檢測邊緣圖像中的輪廓。按降序排序,只保留五個最大的輪廓。通過循環排序后的輪廓,近似獲取最大的四邊輪廓。

cnts, _ = cv2.findContours(edged_img, cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE)
cnts = sorted(cnts, key=cv2.contourArea, reverse=True)[:5]

for c in cnts:
peri = cv2.arcLength(c, True)
approx = cv2.approxPolyDP(c, 0.02 * peri, True)

if len(approx) == 4:
doc = approx
break

有四個邊的輪廓很可能含有文檔。

7、圈出文檔輪廓的四個角

圈出檢測到的文檔輪廓的幾個角。這將幫助您確定您的程序是否能夠檢測圖像中的文檔。

p = []

for d in doc:
tuple_point = tuple(d[0])
cv2.circle(img_resize, tuple_point, 3, (0, 0, 255), 4)
p.append(tuple_point)

cv2.imshow('Circled corner points', img_resize)
cv2.waitKey(0)

對調整后的RGB圖像圈出幾個角。

圖片

檢測到文檔之后,現在需要從圖像中提取文檔。

8、使用扭曲透視獲得所需的圖像

扭曲透視(warp perspective)是一種計算機視覺技術,用于轉換圖像以糾正失真。它將圖像轉換成不同的平面,讓您可以從不同的角度查看圖像。

warped_image = perspective_transform(copy, doc.reshape(4, 2) * ratio)
warped_image = cv2.cvtColor(warped_image, cv2.COLOR_BGR2GRAY)
cv2.imshow("Warped Image", imutils.resize(warped_image, height=650))
cv2.waitKey(0)

為了獲得扭曲后的圖像,您需要創建一個簡單的模塊來執行透視轉換。

9、轉換模塊

該模塊將對文檔角的點進行排序。它還會將文檔圖像轉換成不同的平面,并將相機角度更改為俯拍。

打開之前創建的那個transform.py文件,導入OpenCV庫和NumPy庫。

import numpy as np
import cv2

這個模塊將含有兩個函數。創建一個對文檔角點的坐標進行排序的函數。第一個坐標將是左上角的坐標,第二個將是右上角的坐標,第三個將是右下角的坐標,第四個將是左下角的坐標。

def order_points(pts):
# initializing the list of coordinates to be ordered
rect = np.zeros((4, 2), dtype = "float32")

s = pts.sum(axis = 1)

# top-left point will have the smallest sum
rect[0] = pts[np.argmin(s)]

# bottom-right point will have the largest sum
rect[2] = pts[np.argmax(s)]

'''computing the difference between the points, the
top-right point will have the smallest difference,
whereas the bottom-left will have the largest difference'''
diff = np.diff(pts, axis = 1)
rect[1] = pts[np.argmin(diff)]
rect[3] = pts[np.argmax(diff)]

# returns ordered coordinates
return rect

創建將計算新圖像的角坐標,并獲得俯拍的第二個函數。然后,它將計算透視變換矩陣,并返回扭曲的圖像。

def perspective_transform(image, pts):
# unpack the ordered coordinates individually
rect = order_points(pts)
(tl, tr, br, bl) = rect

'''compute the width of the new image, which will be the
maximum distance between bottom-right and bottom-left
x-coordinates or the top-right and top-left x-coordinates'''
widthA = np.sqrt(((br[0] - bl[0]) ** 2) + ((br[1] - bl[1]) ** 2))
widthB = np.sqrt(((tr[0] - tl[0]) ** 2) + ((tr[1] - tl[1]) ** 2))
maxWidth = max(int(widthA), int(widthB))

'''compute the height of the new image, which will be the
maximum distance between the top-left and bottom-left y-coordinates'''
heightA = np.sqrt(((tr[0] - br[0]) ** 2) + ((tr[1] - br[1]) ** 2))
heightB = np.sqrt(((tl[0] - bl[0]) ** 2) + ((tl[1] - bl[1]) ** 2))
maxHeight = max(int(heightA), int(heightB))

'''construct the set of destination points to obtain an overhead shot'''
dst = np.array([
[0, 0],
[maxWidth - 1, 0],
[maxWidth - 1, maxHeight - 1],
[0, maxHeight - 1]], dtype = "float32")

# compute the perspective transform matrix
transform_matrix = cv2.getPerspectiveTransform(rect, dst)

# Apply the transform matrix
warped = cv2.warpPerspective(image, transform_matrix, (maxWidth, maxHeight))

# return the warped image
return warped

現在您已創建了轉換模塊。perspective_transform導入方面的錯誤現在將消失。

圖片

注意,顯示的圖像有俯拍。

10、運用自適應閾值,保存掃描輸出

在main.py文件中,對扭曲的圖像運用高斯閾值。這將給扭曲的圖像一個掃描后的外觀。將掃描后的圖像輸出保存到含有程序文件的文件夾中。

T = threshold_local(warped_image, 11, offset=10, method="gaussian")
warped = (warped_image > T).astype("uint8") * 255
cv2.imwrite('./'+'scan'+'.png',warped)

以PNG格式保存掃描件可以保持文檔質量。

11、顯示輸出

輸出掃描后文檔的圖像:

cv2.imshow("Final Scanned image", imutils.resize(warped, height=650))
cv2.waitKey(0)
cv2.destroyAllWindows()

下圖顯示了程序的輸出,即掃描后文檔的俯拍。

圖片

12、計算機視覺在如何進步?

創建文檔掃描器涉及計算機視覺的一些核心領域,計算機視覺是一個廣泛而復雜的領域。為了在計算機視覺方面取得進步,您應該從事有趣味又有挑戰性的項目。

您還應該閱讀如何將計算機視覺與當前前技術結合使用方面的更多信息。這讓您能了解情況,并為所處理的項目提供新的想法。

原文鏈接:https://www.makeuseof.com/python-create-document-scanner/

責任編輯:武曉燕 來源: 51CTO技術棧
相關推薦

2011-01-11 10:29:46

2017-06-01 12:53:18

WPSekuWordPress漏洞掃描器

2015-11-26 11:33:54

掃描器

2010-12-22 21:57:00

Angry IP Sc

2023-09-05 09:00:00

工具Python抄襲檢測系統

2016-05-13 17:07:00

Docker安全

2021-04-09 08:00:00

容器開發云原生

2015-11-11 14:08:07

2011-02-17 18:51:10

2010-09-13 15:55:43

制作端口掃描器

2009-03-25 11:21:02

2023-02-13 14:47:32

人工智能機器學習ChatGPT

2013-04-25 13:31:01

漏洞掃描器Nessus 5.2

2010-12-31 13:35:39

2010-12-01 13:05:11

Nikto

2013-08-14 10:24:38

2010-12-16 14:35:52

2018-05-25 08:44:22

樹莓派PythonMySQL

2023-09-21 08:00:00

ChatGPT編程工具

2022-01-05 08:58:08

Python解釋器編程語言
點贊
收藏

51CTO技術棧公眾號

亚洲精品久久嫩草网站秘色| 国产福利一区在线观看| 在线性视频日韩欧美| 日本久久久久久久久久久久| 黄色免费在线观看| 国产大陆a不卡| 亚洲人成午夜免电影费观看| 日本va欧美va瓶| 久久精品免费播放| 日本一卡二卡在线| 精品乱码一区二区三区四区| 亚洲在线成人精品| 色综合久久88色综合天天提莫| 国产农村妇女毛片精品| 亚洲日韩视频| 久久久国产精品亚洲一区| 亚州av综合色区无码一区| 国产黄色精品| 欧美日韩亚洲91| a级网站在线观看| 青青草视频免费在线观看| 激情五月播播久久久精品| 欧美在线观看视频| 国产av无码专区亚洲av毛网站| 日韩精品a在线观看91| 欧美军同video69gay| 能在线观看的av| 欧美videossex| 国产精品久久久久天堂| 蜜桃成人在线| 色综合视频在线| 国产精品99久久久久久宅男| 国产精品电影一区| 啦啦啦免费高清视频在线观看| 一本到12不卡视频在线dvd| 亚洲图片在区色| 亚洲视频在线播放免费| 欧美另类中文字幕| 欧美精品一级二级| 校园春色 亚洲色图| 在线中文字幕播放| 精品国产1区2区| 国产又粗又猛又爽又黄的网站| 自拍视频在线免费观看| 国产亚洲欧美日韩日本| 久久国产日韩欧美| 亚洲 欧美 激情 小说 另类| 国产一区二区三区免费在线观看| 国产精品爽爽ⅴa在线观看| 午夜精品免费观看| 国产精品一二| 欧美亚洲另类激情另类| 亚洲国产成人精品激情在线| 在线看片欧美| 久久久免费精品| 欧美亚洲天堂网| 国产亚洲欧洲| 欧美在线视频免费观看| 亚洲s码欧洲m码国产av| 亚洲综合社区| 国产不卡在线观看| 日韩精品在线一区二区三区| 日韩不卡手机在线v区| 国产精品久久91| 中文字幕在线观看高清| 久久91精品国产91久久小草 | 国产美女久久久久久| 欧美aaaa视频| 久久视频在线播放| 欧美三级在线免费观看| 尤物精品在线| 欧美影院在线播放| 亚洲熟妇av乱码在线观看| 久草热8精品视频在线观看| 91老司机在线| 乱色精品无码一区二区国产盗| 菠萝蜜视频在线观看一区| 久久久久一区二区| 国产一区二区三区福利| 国产精品国产三级国产普通话三级| 爱爱爱视频网站| 18+视频在线观看| 黄色一区二区在线观看| 能看的毛片网站| 亚洲我射av| 欧美成人aa大片| 国产又爽又黄无码无遮挡在线观看| 国产日产一区| 久久久精品国产一区二区| 久久无码精品丰满人妻| 午夜在线一区二区| 国产免费一区视频观看免费| 精品人妻一区二区三区麻豆91| 成人在线视频首页| 日韩欧美第二区在线观看| av香蕉成人| 日韩欧美a级成人黄色| 污版视频在线观看| 超碰成人在线观看| 中文字幕v亚洲ⅴv天堂| 久久久久成人片免费观看蜜芽| 久久国产88| 51午夜精品| 狠狠v欧美ⅴ日韩v亚洲v大胸| 综合婷婷亚洲小说| 人妻有码中文字幕| 国产精一区二区| 亚洲欧美日韩直播| 久久久久久激情| 久久成人精品无人区| 精品视频导航| 少女频道在线观看高清| 欧美中文字幕一区二区三区| 亚洲视频天天射| 97精品国产福利一区二区三区| 97精品一区二区视频在线观看| 国产精品无码天天爽视频| 91首页免费视频| 强开小嫩苞一区二区三区网站| 天堂av中文在线观看| 欧美一卡二卡三卡四卡| 天天舔天天操天天干| 亚洲福利电影| 亚洲最大成人免费视频| 日本精品在线| 在线日韩国产精品| 亚洲av片不卡无码久久| 亚洲午夜一区| 亚洲xxx大片| 免费观看在线黄色网| 一本大道久久a久久综合婷婷| 亚洲精品成人无码毛片| 一区二区不卡| 成人福利免费观看| 91青青在线视频| 在线视频中文字幕一区二区| 男生裸体视频网站| 亚洲国产婷婷| 国产乱码一区| 国产第一页在线视频| 精品国产亚洲在线| 久久免费视频6| 成人av综合在线| 国产九色porny| 国产 日韩 欧美 综合 一区| 欧美黑人性猛交| 亚洲AV午夜精品| 一区二区三区四区激情| 97人人模人人爽人人澡| 亚洲精品小说| 91沈先生播放一区二区| 在线网址91| 日韩欧美中文字幕制服| 久草国产在线观看| 风间由美一区二区三区在线观看| 成人在线观看毛片| 91精品国产自产在线丝袜啪| 欧美精品九九久久| 欧美一区二区公司| 欧美色图在线视频| 亚洲精品色午夜无码专区日韩| 奶水喷射视频一区| 日韩欧美精品一区二区| 国产成人77亚洲精品www| 日韩有码在线视频| 国产av一区二区三区精品| 亚洲一区在线观看免费| 精品影片一区二区入口| 亚洲综合好骚| 亚洲午夜精品久久久久久浪潮| 日本亚洲欧洲无免费码在线| 久久香蕉国产线看观看av| japanese国产| 精品久久久视频| 大地资源二中文在线影视观看| 久久久www| 少妇熟女一区二区| 成人涩涩网站| 国产精品91在线观看| 欧美精品hd| 精品免费视频.| 91精品国产高清一区二区三密臀| 国产精品网友自拍| 亚洲区 欧美区| 噜噜噜久久亚洲精品国产品小说| 亚洲高清视频一区| 一区二区三区视频播放| 日本高清久久天堂| 草莓福利社区在线| 亚洲精品资源在线| 国产乱淫av免费| 精品久久久久久亚洲精品| 日本午夜精品视频| 成年人网站91| 免费成年人高清视频| 亚洲天堂男人| 视频一区国产精品| jizz18欧美18| 国产精品无av码在线观看| 欧洲成人综合网| 日韩在线视频网站| 水莓100国产免费av在线播放| 欧美日韩一区二区三区在线看| 私库av在线播放| 国产婷婷色一区二区三区| 手机在线观看日韩av| 首页亚洲欧美制服丝腿| 日韩免费在线观看av| 第一会所亚洲原创| 国产在线欧美日韩| 国产精品亚洲四区在线观看| 日本免费久久高清视频| 性欧美1819sex性高清大胸| 一道本无吗dⅴd在线播放一区 | 亚洲精品久久久久久国| 久久综合久久鬼色| 中文字幕天堂av| 精品一区二区三区蜜桃| 成年人视频在线免费| 伊人激情综合| 日本福利视频网站| 日韩精品不卡一区二区| 欧美福利精品| 麻豆视频一区| 国产91视觉| 国产一区二区三区黄网站| 国产精品黄视频| 色网在线免费观看| 久久久久久久一| 午夜伦理大片视频在线观看| 日韩中文字幕在线免费观看| 久久久久久女乱国产| 亚洲激情自拍图| 欧美熟女一区二区| 日韩精品一区二区三区中文精品| 在线观看国产成人| 欧美制服丝袜第一页| 4438国产精品一区二区| 欧美午夜精品久久久久久久| 日韩乱码一区二区| 亚洲国产另类精品专区| 欧美人妻精品一区二区免费看| 成人欧美一区二区三区黑人麻豆 | 国产黄色一区二区三区 | 91精品人妻一区二区三区四区| 麻豆91在线观看| 亚欧美在线观看| 久久精品国产亚洲高清剧情介绍 | 欧美黑人经典片免费观看| 黄色精品一区| 亚洲国产精品无码观看久久| 国内自拍一区| 美女扒开大腿让男人桶| 欧美日韩三区| 久久久久久人妻一区二区三区| 黄色日韩在线| 久色视频在线播放| 六月丁香综合| 亚洲最大成人在线观看| 精品亚洲欧美一区| 久久无码人妻一区二区三区| 国产精品一区二区不卡| 制服丝袜在线第一页| 白白色 亚洲乱淫| 无套内谢大学处破女www小说| 2020国产精品| 亚洲色图欧美色| 国产精品久久久久久久久果冻传媒| 免费看日本黄色片| 自拍偷拍亚洲综合| 久久久久久久久久久久久久久久久| 一二三四社区欧美黄| 日韩av女优在线观看| 日韩欧美视频一区二区三区| 欧美高清69hd| 日韩免费电影网站| 天天射,天天干| 亚洲图片欧洲图片av| 超鹏97在线| 热久久免费国产视频| 狠狠久久伊人中文字幕| 97欧洲一区二区精品免费| 美女一区二区在线观看| 午夜精品一区二区在线观看| 自产国语精品视频| 免费在线观看亚洲视频| 丝袜诱惑亚洲看片| 麻豆传媒在线看| 91色视频在线| 三上悠亚在线观看视频| 亚洲国产精品欧美一二99| 天天综合久久综合| 日韩精品一区二区三区中文不卡 | 中文字幕精品在线| 牛牛精品在线视频| 国产精品xxxxx| 日韩精品视频在线看| 蜜桃91精品入口| 欧美不卡视频| 国产精品无码av无码| 国产精品中文字幕日韩精品 | 超碰在线播放97| 亚洲小视频在线观看| 黄色成人在线网| 国产精品香蕉av| 欧美一性一交| 男女h黄动漫啪啪无遮挡软件| 欧美专区18| 制服丝袜在线第一页| 中文字幕一区视频| 精品国产午夜福利| 精品粉嫩超白一线天av| 日本综合在线| 国产成人精品久久久| eeuss国产一区二区三区四区| 国产高清精品软男同| 免费一区视频| 无码国产精品一区二区免费式直播| 国产欧美日本一区二区三区| 欧美福利视频一区二区| 欧美一级淫片007| 啊v在线视频| 日本亚洲精品在线观看| jizz久久精品永久免费| 青青视频免费在线观看| 免费欧美日韩国产三级电影| 国产制服丝袜在线| 亚洲国产精品麻豆| 成 人 免费 黄 色| 美日韩在线视频| 亚洲国产天堂| 亚洲va久久久噜噜噜久久狠狠 | 日韩一级在线播放| 欧美成人自拍视频| 99久久久国产| 综合久久国产| 九九久久精品视频| а天堂中文在线资源| 欧美日韩中文字幕一区| av在线中文| 国产精品香蕉av| 99精品小视频| 57pao国产成永久免费视频| 国产精品网友自拍| 在线亚洲欧美日韩| 日韩综合中文字幕| 亚洲免费看片| 国产又爽又黄ai换脸| 免费观看日韩电影| 999福利视频| 欧美人狂配大交3d怪物一区| 国产婷婷视频在线| 91在线精品观看| 国产一区二区三区自拍| 亚洲国产精品狼友在线观看| 亚洲国产综合色| 视频一区二区三区国产| 久久久噜噜噜久久久| 亚洲区小说区| 国产av人人夜夜澡人人爽| 国产午夜久久久久| 亚洲一线在线观看| 久久成人精品视频| 大香伊人久久精品一区二区| 国产3p露脸普通话对白| 久久综合久色欧美综合狠狠| 潘金莲一级淫片aaaaaa播放| 一色桃子一区二区| 9999精品视频| 东北少妇不带套对白| 国产亚洲一二三区| 99精品久久久久久中文字幕| 欧美日韩成人在线播放| 免费萌白酱国产一区二区三区| 国产性xxxx18免费观看视频| 欧美国产一区二区| 国产男女裸体做爰爽爽| 国语自产精品视频在线看一大j8| 免费黄色成人| www.成年人| 激情成人在线视频| а√天堂中文在线资源bt在线 | 久久aimee| 9久久婷婷国产综合精品性色| 亚洲美女偷拍久久| 午夜视频福利在线观看| 国产精品久久久久久久久久东京 | 免费欧美激情| 九九久久久久久| 欧美性高潮在线| 黄色免费网站在线观看| 国产一区二区视频在线免费观看| 奇米影视一区二区三区小说| 久久丫精品久久丫| 国产亚洲精品久久久| 91成人短视频| 中文字幕第17页| 欧美视频免费在线观看| 日本a级在线| 鲁丝片一区二区三区|