1
我是一名python程序員,並專門用python編寫了很多程序處理工具箱。 我寫了一個程序,從這個驗證碼刪除行:通過中值濾波 https://ibb.co/ncED3v 首先我提高圖像的可見度如何從驗證碼中完全刪除線
def apply_median_filter(self,img):
img_gray=img.convert('L')
img_gray=cv2.medianBlur(np.asarray(img_gray),3)
img_bw=(img_gray>np.mean(img_gray))*255
return img_bw
然後我嘗試刪除行:
def eliminate_zeros(self,vector):
return [(dex,v) for (dex,v) in enumerate(vector) if v!=0 ]
def get_line_position(self,img):
sumx=img.sum(axis=0)
list_without_zeros=self.eliminate_zeros(sumx)
min1,min2=heapq.nsmallest(2,list_without_zeros,key=itemgetter(1))
l=[dex for [dex,val] in enumerate(sumx) if val==min1[1] or val==min2[1]]
mindex=[l[0],l[len(l)-1]]
cols=img[:,mindex[:]]
col1=cols[:,0]
col2=cols[:,1]
col1_without_0=self.eliminate_zeros(col1)
col2_without_0=self.eliminate_zeros(col2)
line_length=len(col1_without_0)
dex1=col1_without_0[round(len(col1_without_0)/2)][0]
dex2=col2_without_0[round(len(col2_without_0)/2)][0]
p1=[dex1,mindex[0]]
p2=[dex2,mindex[1]]
return p1,p2,line_length
終於被我刪除線由其位置:
def remove_line(self,p1,p2,LL,img):
m=(p2[0]-p1[0])/(p2[1]-p1[1]) if p2[1]!=p1[1] else np.inf
w,h=len(img),len(img[0])
x=[x for x in range(w)]
y=[p1[0]+k for k in [m*t for t in [v-p1[1] for v in x]]]
img_removed_line=img
for dex in range(w):
i,j=np.round([y[dex],x[dex]])
i=int(i)
j=int(j)
rlist=[]
while True:
f1=i
if img_removed_line[i,j]==0 and img_removed_line[i-1,j]==0:
break
rlist.append(i)
i=i-1
i,j=np.round([y[dex],x[dex]])
i=int(i)
j=int(j)
while True:
f2=i
if img_removed_line[i,j]==0 and img_removed_line[i+1,j]==0:
break
rlist.append(i)
i=i+1
print([np.abs(f2-f1),[LL+1,LL,LL-1]])
if np.abs(f2-f1) in [LL+1,LL,LL-1]:
rlist=list(set(rlist))
img_removed_line[rlist,j]=0
return img_removed_line
但在某些情況下行不完全刪除,我得到帶有一些噪音的驗證碼圖像: https://ibb.co/bKPKbF 請幫助我一些想法!