麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Python > 正文

用Python去除圖像的黑色或白色背景實例

2024-09-09 19:03:16
字體:
來源:轉載
供稿:網友

用Python去除背景,得到有效的圖像

此目的是為了放入深度學習計算中來減少計算量,同時突出特征,原圖像為下圖,命名為1.jpg,在此去除白色背景,黑色背景同理

需要對原圖像進行的處理是去掉白色背景,摳出有效的參與計算的圖形的大小即下圖

對此有兩個思路:

用掩模法得到有效部分,其次去掉空白,但太繁瑣嘍,并且一萬多張圖片,其不弄到天荒地老(截圖也是哦)

對圖像進行處理,即先做numpy變化,后反變換,將255-原圖像,此時得到的圖像就是

在此計算圖像的橫軸相加為0,縱軸相加為0,刪去和為0的列和行得到的numpy矩陣,用255減去numpy矩陣得到的圖像就是所求有效圖像。(在此我沒能實現三通道的圖像,只能做出灰度圖的圖像)程序如下:

from PIL import Imageimport numpy as npimport pandas as pdimport matplotlib.pyplot as pltimport scipy.miscimg = Image.open('1.jpg')e,g=img.sizeimg1=img.convert('L')img1=np.array(img1, dtype='float32')arr=255-img1arr1 = arr.sum(axis=0)#每一列求和arr2 = arr.sum(axis=1)#每一行求和df=pd.DataFrame(arr)#把像素點轉化為dataframedf.insert(len(df.columns),len(df.columns),arr2)#最后一列插入每一行的和df1=pd.concat([df,(pd.DataFrame(df.sum()).T)])#最后一行插入每一列的和df2=df1[df1[e]>0]#根據最后一列把大于0的行篩選出來#根據最后一行,把等于0的列刪除掉for c in df2.columns:  if df2[c].sum() == 0 :    df2.drop(columns = [c],inplace = True)    df2.drop(columns=[e],inplace = True)#刪除最后一列df3 = df2.head((df2.shape[0])-1)#刪除最后一行a=255-df3#df3.values#dataframe轉化為numpyplt.imshow(a)scipy.misc.toimage(df3.values).save('C:/Users/Administrator.SKY-20180518VHY/Desktop/2.jpg')#保存圖像

最終得到的圖像為

在此處考慮過將圖像變為列表,但在此處做嵌套列表太為復雜,因而放棄,最終利用DataFrame做的,本考慮將三通道分開分別作運算最終得到的R、G、B三通道圖像由于大小不匹配無法整合到一起,又失敗了。只能得到單通道湊合弄吧。誰有好的思路,求溝通…

完整程序:

import osfrom PIL import Imageimport numpy as npimport pandas as pdimport matplotlib.pyplot as pltimport scipy.miscdef save_pic(file_path):  c = []  names = os.listdir(file_path) #路徑  #將文件夾中的文件名稱與后邊的 .dcm分開  for name in names:    c.append(name)  for files in c :    img = Image.open(file_path+'//'+files)    e,g=img.size    img1=img.convert('L')    img1=np.array(img1, dtype='float32')    arr=255-img1    arr1 = arr.sum(axis=0)#每一列求和    arr2 = arr.sum(axis=1)#每一行求和    df=pd.DataFrame(arr)#把像素點轉化為dataframe    df.insert(len(df.columns),len(df.columns),arr2)#最后一列插入每一行的和    df1=pd.concat([df,(pd.DataFrame(df.sum()).T)])#最后一行插入每一列的和    df2=df1[df1[e]>0]#根據最后一列把大于0的行篩選出來        #根據最后一行,把等于0的列刪除掉    for c in df2.columns:      if df2[c].sum() == 0 :        df2.drop(columns = [c],inplace = True)            df2.drop(columns=[e],inplace = True)#刪除最后一列    df3 = df2.head((df2.shape[0])-1)#刪除最后一行    #df3.values#dataframe轉化為numpy    a=255-df3     plt.imshow(a)    scipy.misc.toimage(a).save('C:/Users/Administrator.SKY-20180518VHY/Desktop'+'/'+files)#保存圖像  print('all is saved')    save_pic(file_path='C://Users//Administrator.SKY-20180518VHY//Desktop//1')  
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 特色一级黄色片 | 亚洲一区二区三区视频免费 | gril hd| 羞羞视频入口 | 欧洲成人一区 | 在线成人亚洲 | 毛片视频网站 | 一级做人爱c黑人影片 | 亚洲第一页夜 | 午夜色片 | 国产一区二区高清在线 | 国产 日韩 亚洲 欧美 | 成人h精品动漫一区二区三区 | 成人青青草 | www.理论片 | 91精品国产91久久久久久 | 羞羞视频免费入口网站 | 一级毛片电影网 | 日本高清在线免费 | 草草视频免费观看 | 男女无套免费视频 | 99精品视频久久精品视频 | 国产成人精品二区 | 国产精品一区在线观看 | 欧美国产免费 | 777zyz色资源站在线观看 | 国产亚洲精品久久久久婷婷瑜伽 | 毛片大全| 99国产精品白浆在线观看免费 | 国产成人精品免费视频大全最热 | 伦理三区 | 暖暖免费观看高清完整版电影 | 中国av免费在线观看 | 午夜精品区| 亚洲精品3 | 激情久久免费视频 | 激情在线视频 | 成人 精品 | 黄色香蕉视频 | 九九热精 | 孕妇体内谢精满日本电影 |