forked from iambus/xunlei-lixian
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathascii_verification_code.py
92 lines (86 loc) · 2.27 KB
/
ascii_verification_code.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
# -*- coding: utf-8 -*-
from PIL import Image
from StringIO import StringIO
__author__ = 'deadblue'
def convert_to_ascii(img_data):
return _martix_to_ascii(
_crop_and_border(
_image_to_martix(img_data)
)
)
def _image_to_martix(img_data):
img = Image.open(StringIO(img_data)).convert('L')
w,h = img.size
martix = []
for y in xrange(h / 2):
row = []
for x in xrange(w):
p1 = img.getpixel((x, y * 2))
p2 = img.getpixel((x, y * 2 + 1))
if p1 > 192 and p2 > 192:
row.append(0)
elif p1 > 192:
row.append(1)
elif p2 > 192:
row.append(2)
else:
row.append(3)
martix.append(row)
return martix
def _crop_and_border(martix):
# 测量四周空白大小
t,b,l,r = 0,0,0,0
for y in xrange(len(martix)):
if sum(martix[y]) == 0:
t += 1
else: break
for y in xrange(len(martix)):
if sum(martix[-1 - y]) == 0:
b += 1
else: break
for x in xrange(len(martix[0])):
if sum( map(lambda row:row[x], martix) ) == 0:
l += 1
else: break
for x in xrange(len(martix[0])):
if sum( map(lambda row:row[-1 - x], martix) ) == 0:
r += 1
else: break
# 上下裁剪与补边
w = len(martix[0])
if t > 0:
martix = martix[t-1:]
else:
martix.insert(0, [0] * w)
if b > 1:
martix = martix[:1-b]
elif b == 0:
martix.append([0] * w)
# 左右裁剪与补边
for ri in xrange(len(martix)):
row = martix[ri]
if l > 0:
row = row[l-1:]
else:
row.insert(0, 0)
if r > 1:
row = row[:1-r]
elif r == 0:
row.append(0)
martix[ri] = row
return martix
def _martix_to_ascii(martix):
buf = []
for row in martix:
rbuf = []
for cell in row:
if cell == 0:
rbuf.append('#')
elif cell == 1:
rbuf.append('"')
elif cell == 2:
rbuf.append(',')
elif cell == 3:
rbuf.append(' ')
buf.append(''.join(rbuf))
return '\n'.join(buf)