婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python使用opencv切割圖片白邊

python使用opencv切割圖片白邊

熱門標簽:高德地圖標注收入咋樣 萊蕪電信外呼系統 銀川電話機器人電話 B52系統電梯外呼顯示E7 怎么辦理400客服電話 地圖標注多個 鶴壁手機自動外呼系統違法嗎 沈陽防封電銷電話卡 企業微信地圖標注

本文實例為大家分享了python使用opencv切割圖片白邊的具體代碼,可以橫切和豎切,供大家參考,具體內容如下

廢話不多說直接上碼,分享使人進步:

from PIL import Image
from itertools import groupby
import cv2
import datetime
import os
 
# from core.rabbitmq import MessageQueue
 
THRESHOLD_VALUE = 230  # 二值化時的閾值
PRETREATMENT_FILE = 'hq'  # 橫切時臨時保存的文件夾
W = 540  # 最小寬度
H = 960  # 最小高度
 
 
class Pretreatment(object):
    __doc__ = "圖片橫向切割"
 
    def __init__(self, path, save_path, min_size=960):
        self.x = 0
        self.y = 0
        self.img_section = []
        self.continuity_position = []
        self.path = path
        self.save_path = save_path
        self.img_obj = None
        self.min_size = min_size
        self.mkdir(self.save_path)
        self.file_name = self.path.split('/')[-1]
 
    def get_continuity_position_new(self):
        img = cv2.imread(self.path)
        gray_image = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
        ret, thresh1 = cv2.threshold(gray_image, THRESHOLD_VALUE, 255, cv2.THRESH_BINARY)
 
        width = img.shape[1]
        height = img.shape[0]
        self.x = width
        self.y = height
        for i in range(0, height):
            if thresh1[i].sum() != 255 * width:
                self.continuity_position.append(i)
 
    def filter_rule(self):
        if self.y  self.min_size:
            return True
 
    def mkdir(self, path):
        if not os.path.exists(path):
            os.makedirs(path)
 
    def get_section(self):
        # 獲取區間
        for k, g in groupby(enumerate(self.continuity_position), lambda x: x[1] - x[0]):
            l1 = [j for i, j in g]  # 連續數字的列表
            if len(l1) > 1:
                self.img_section.append([min(l1), max(l1)])
 
    def split_img(self):
        print(self.img_section)
        for k, s in enumerate(self.img_section):
            if s:
                if not self.img_obj:
                    self.img_obj = Image.open(self.path)
 
                if self.x  W:
                    return
                if s[1] - s[0]  H:
                    return
                cropped = self.img_obj.crop((0, s[0], self.x, s[1]))  # (left, upper, right, lower)
                self.mkdir(os.path.join(self.save_path, PRETREATMENT_FILE))
                cropped.save(os.path.join(self.save_path, PRETREATMENT_FILE, f"hq_{k}_{self.file_name}"))
 
    def remove_raw_data(self):
        os.remove(self.path)
 
    def main(self):
        # v2
        try:
            self.get_continuity_position_new()
            self.filter_rule()
            self.get_section()
            self.split_img()
        except Exception as e:
            print(self.file_name)
            print(e)
        finally:
            if self.img_obj:
                self.img_obj.close()
 
 
class Longitudinal(Pretreatment):
    def get_continuity_position_new(self):
        print(self.path)
        img = cv2.imread(self.path)
        gray_image = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
        ret, thresh1 = cv2.threshold(gray_image, THRESHOLD_VALUE, 255, cv2.THRESH_BINARY)
 
        width = img.shape[1]
        height = img.shape[0]
        print(width, height)
        self.x = width
        self.y = height
        for i in range(0, width):
            if thresh1[:, i].sum() != 255 * height:
                self.continuity_position.append(i)
 
    def split_img(self):
        print(self.img_section)
        for k, s in enumerate(self.img_section):
            if s:
                if not self.img_obj:
                    self.img_obj = Image.open(self.path)
                if self.y  H:
                    return
                if s[1] - s[0]  W:
                    return
                cropped = self.img_obj.crop((s[0], 0, s[1], self.y))  # (left, upper, right, lower)
                cropped.save(os.path.join(self.save_path, f"{k}_{self.file_name}"))
 
 
def main(path, save_path):
    starttime = datetime.datetime.now()
    a = Pretreatment(path=path, save_path=save_path)
    a.main()
    for root, dirs, files in os.walk(os.path.join(save_path, PRETREATMENT_FILE)):
        for i in files:
            b = Longitudinal(path=os.path.join(save_path, PRETREATMENT_FILE, i), save_path=save_path)
            b.main()
            os.remove(os.path.join(save_path, PRETREATMENT_FILE, i))
    endtime = datetime.datetime.now()
    print(f'耗時:{(endtime - starttime)}')
 
 
if __name__ == '__main__':
    path = '你圖片存放的路徑'
    save_path = '要保存的路徑'
    for _, _, files in os.walk(path):
        for i in files:
            main(path=os.path.join(path, i), save_path=save_path)
    os.rmdir(os.path.join(save_path, PRETREATMENT_FILE))

原始圖片:

結果:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • python切割圖片的示例
  • Python切割圖片成九宮格的示例代碼
  • python3 實現驗證碼圖片切割的方法
  • python實現對任意大小圖片均勻切割的示例
  • python3 實現對圖片進行局部切割的方法

標簽:蘭州 懷化 蕪湖 廣西 紹興 吉安 呂梁 安康

巨人網絡通訊聲明:本文標題《python使用opencv切割圖片白邊》,本文關鍵詞  python,使用,opencv,切割,圖片,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python使用opencv切割圖片白邊》相關的同類信息!
  • 本頁收集關于python使用opencv切割圖片白邊的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美日韩国产成人在线免费| 久久久影视传媒| 精品久久国产字幕高潮| 五月婷婷激情综合| 精品视频在线看| 亚洲人成网站影音先锋播放| 99精品欧美一区| 日韩伦理电影网| 欧美中文字幕一区| 亚洲丰满少妇videoshd| 欧美精品久久久久久久多人混战 | 久久99久国产精品黄毛片色诱| 精品1区2区3区| 天天av天天翘天天综合网色鬼国产| 欧美美女bb生活片| 国产成a人亚洲| 亚洲小说春色综合另类电影| 91精品国产一区二区三区| 麻豆视频观看网址久久| 欧美国产日本视频| 欧美日韩国产中文| 国产91精品免费| 日韩国产欧美三级| 国产三级一区二区三区| 欧美亚洲综合久久| 久久精品国产澳门| 亚洲欧洲综合另类| 久久综合久久99| 欧美日韩一区二区三区高清| 国产乱码精品一区二区三| 亚洲乱码国产乱码精品精小说| 日韩限制级电影在线观看| 国产一区二区三区高清播放| 亚洲成人你懂的| 国产精品毛片a∨一区二区三区 | 日韩欧美亚洲另类制服综合在线| 福利电影一区二区| 三级久久三级久久| 中文字幕一区免费在线观看| 日韩午夜精品电影| 日本精品一级二级| 99久免费精品视频在线观看| 韩国成人福利片在线播放| 午夜私人影院久久久久| 亚洲黄色录像片| 中文字幕亚洲综合久久菠萝蜜| 精品国产一区二区国模嫣然| 欧美日韩国产精品成人| 91国产丝袜在线播放| 成熟亚洲日本毛茸茸凸凹| 乱中年女人伦av一区二区| 亚洲国产精品一区二区久久恐怖片 | 欧美性做爰猛烈叫床潮| 成人高清av在线| 国产另类ts人妖一区二区| 麻豆精品在线观看| 三级久久三级久久| 免费在线一区观看| 午夜婷婷国产麻豆精品| 午夜婷婷国产麻豆精品| 日韩精品一二三| 久久精品国产亚洲a| 捆绑调教一区二区三区| 麻豆国产欧美日韩综合精品二区 | 亚洲夂夂婷婷色拍ww47| 亚洲品质自拍视频网站| 亚洲欧美日本在线| 亚洲欧美中日韩| 亚洲精品国产一区二区三区四区在线| 中文字幕中文字幕一区二区| 中文字幕亚洲精品在线观看 | 97se亚洲国产综合在线| 91老司机福利 在线| 欧洲人成人精品| 欧美福利视频导航| 2021久久国产精品不只是精品| 国产欧美日韩视频在线观看| 国产精品丝袜久久久久久app| 亚洲欧洲另类国产综合| 亚洲最快最全在线视频| 欧美aaaaa成人免费观看视频| 国产一区二区福利视频| 国产成人高清视频| 99国产精品一区| 欧美性色黄大片手机版| 欧美一级在线视频| 久久在线免费观看| 亚洲日本韩国一区| 美女任你摸久久| 成人av在线播放网站| 欧美日韩精品系列| 国产亚洲一区二区在线观看| 亚洲精品五月天| 麻豆91小视频| 91免费看片在线观看| 制服丝袜中文字幕亚洲| 日本一区二区三区四区在线视频| 一区二区三区丝袜| 国模套图日韩精品一区二区| 91黄色激情网站| www国产成人| 一级精品视频在线观看宜春院| 日产国产欧美视频一区精品| 成人丝袜18视频在线观看| 555夜色666亚洲国产免| 中文字幕综合网| 老司机精品视频线观看86| 99精品视频在线观看| 日韩午夜在线观看视频| 亚洲精品一二三区| 国产精品一二三区| 欧美一区二区三区小说| 亚洲影院在线观看| 国产成都精品91一区二区三| 欧美一级日韩不卡播放免费| 亚洲精品日日夜夜| 不卡一区二区在线| 亚洲精品一区二区三区四区高清| 亚洲午夜久久久久中文字幕久| 国产精品一区二区免费不卡| 日韩一区二区三| 午夜激情综合网| 欧洲亚洲国产日韩| 亚洲精品高清视频在线观看| hitomi一区二区三区精品| 久久综合九色综合欧美亚洲| 日韩中文字幕区一区有砖一区 | 亚洲成a人片在线观看中文| 成人av午夜电影| 中文字幕av一区 二区| 国产一区二区三区观看| 精品av久久707| 国产一区免费电影| 久久婷婷国产综合精品青草| 久久99国产精品久久99| 日韩视频在线你懂得| 男女激情视频一区| 精品久久久久久久人人人人传媒| 久久精品国产澳门| 久久一留热品黄| 国产成人免费在线| 国产精品三级av在线播放| 不卡视频一二三四| 亚洲六月丁香色婷婷综合久久| 色狠狠综合天天综合综合| 亚洲精品视频一区| 欧美日本在线观看| 日韩成人免费看| 亚洲精品一区二区三区在线观看| 激情久久久久久久久久久久久久久久| 7777女厕盗摄久久久| 免费成人结看片| 国产清纯美女被跳蛋高潮一区二区久久w| 久久国产婷婷国产香蕉| 精品国产91亚洲一区二区三区婷婷| 黑人精品欧美一区二区蜜桃| 国产精品伦一区| 精品视频在线视频| 日本成人在线不卡视频| 精品国产免费人成电影在线观看四季| 国产精品66部| 亚洲一区在线观看网站| 精品国产三级电影在线观看| 国产不卡视频一区二区三区| 亚洲在线成人精品| 久久久久九九视频| 色综合久久66| 国产一区二区三区视频在线播放| 亚洲乱码精品一二三四区日韩在线 | 国产成人综合视频| 亚洲人xxxx| 精品美女一区二区三区| 91麻豆免费视频| 精一区二区三区| 亚洲精品久久久蜜桃| 欧美成人精品二区三区99精品| 成人国产一区二区三区精品| 日日摸夜夜添夜夜添国产精品| 中文字幕第一页久久| 日韩亚洲电影在线| 在线精品视频一区二区三四| 国产乱色国产精品免费视频| 亚洲一二三四区不卡| 国产日本欧美一区二区| 91精品国产综合久久福利| 91丨九色丨黑人外教| 国产在线不卡一卡二卡三卡四卡| 亚洲一区二三区| 国产精品久久久久永久免费观看| 欧美精品三级在线观看| 色又黄又爽网站www久久| 国内成人免费视频| 秋霞影院一区二区| 一区二区三区色| 国产精品素人一区二区| 精品国产不卡一区二区三区| 欧美一区二区三区在线观看视频| 欧美日韩卡一卡二| 91九色最新地址| 91黄色免费网站|