TypeError: Int object is not iterable
TypeError: Int object is not iterable
我正在尝试使用不同的字体为 OCR 生成数据集,但是在某个 for 循环中,迭代给了我错误 Typeerror: int object is not iterable.
我进行了足够的搜索,得出结论,Whosebug 上的大多数答案都建议在我的 for 循环中使用范围,包括 (len),但我不确定我是否遵循了这一点。
函数如下:
def gen_rand_string_data(data_count,
min_char_count=3,
max_char_count=8,
max_char=16,
x_pos='side',
img_size=(32, 256, 1),
font=cv2.FONT_HERSHEY_SIMPLEX,
font_scale=np.arange(0.7, 1, 0.1),
thickness=range(1, 3, 1)):
'''
random string data generation
'''
start_time = dt.datetime.now()
images = []
labels = []
color = (255, 255, 255)
count = 0
char_list = list(string.ascii_letters) \
+ list(string.digits) \
+ list(' ')
while (1):
for fs in font_scale:
for thick in thickness:
for f in font:
img = np.zeros(img_size, np.uint8)
char_count = np.random.randint(min_char_count, \
(max_char_count + 1))
rand_str = ''.join(np.random.choice(char_list, \
char_count))
# generate image data
text_size = cv2.getTextSize(rand_str, f, fs, thick)[0]
if x_pos == 'side':
org_x = 0
else:
org_x = (img_size[1] - text_size[0]) // 2
org_y = (img_size[0] + text_size[1]) // 2
cv2.putText(img, rand_str, (org_x, org_y), f, fs, \
color, thick, cv2.LINE_AA)
label = list(rand_str) + [' '] \
* (max_char - len(rand_str))
for i, t in enumerate(label):
label[i] = char_list.index(t)
label = np.uint8(label)
images.append(img)
labels.append(label)
count += 1
if count == data_count:
break
else:
continue
break
else:
continue
break
else:
continue
break
end_time = dt.datetime.now()
print("time taken to generate data", end_time - start_time)
return images, labels
出现的错误在行:for f in font:
我在这里做错了什么?我必须使用 range() 吗?
font=cv2.FONT_HERSHEY_SIMPLEX
for f in font:
...
在 CV2 中,字体是代表字体本身的简单整数,我不是完全确定(a)为什么你正在尝试对其进行迭代。
如果您想遍历字体的 大小 ,则必须使用(例如)putText()
的 fontScale
参数。
如果您想迭代 字体集合 ,您必须提供该集合,例如以下之一:
font = [cv2.FONT_HERSHEY_SIMPLEX] # one font as a collection
font = [cv2.FONT_HERSHEY_SIMPLEX, cv2.FONT_HERSHEY_PLAIN] # two fonts
如果您只有 one 字体,则根本不要对其进行迭代。摆脱 for f in font
行(取消缩进当前“内部”的内容)并在当前使用 f
.
的任何地方使用 font
(a) Python 有 similar 麻烦试图弄清楚你的意图:-)
我正在尝试使用不同的字体为 OCR 生成数据集,但是在某个 for 循环中,迭代给了我错误 Typeerror: int object is not iterable.
我进行了足够的搜索,得出结论,Whosebug 上的大多数答案都建议在我的 for 循环中使用范围,包括 (len),但我不确定我是否遵循了这一点。
函数如下:
def gen_rand_string_data(data_count,
min_char_count=3,
max_char_count=8,
max_char=16,
x_pos='side',
img_size=(32, 256, 1),
font=cv2.FONT_HERSHEY_SIMPLEX,
font_scale=np.arange(0.7, 1, 0.1),
thickness=range(1, 3, 1)):
'''
random string data generation
'''
start_time = dt.datetime.now()
images = []
labels = []
color = (255, 255, 255)
count = 0
char_list = list(string.ascii_letters) \
+ list(string.digits) \
+ list(' ')
while (1):
for fs in font_scale:
for thick in thickness:
for f in font:
img = np.zeros(img_size, np.uint8)
char_count = np.random.randint(min_char_count, \
(max_char_count + 1))
rand_str = ''.join(np.random.choice(char_list, \
char_count))
# generate image data
text_size = cv2.getTextSize(rand_str, f, fs, thick)[0]
if x_pos == 'side':
org_x = 0
else:
org_x = (img_size[1] - text_size[0]) // 2
org_y = (img_size[0] + text_size[1]) // 2
cv2.putText(img, rand_str, (org_x, org_y), f, fs, \
color, thick, cv2.LINE_AA)
label = list(rand_str) + [' '] \
* (max_char - len(rand_str))
for i, t in enumerate(label):
label[i] = char_list.index(t)
label = np.uint8(label)
images.append(img)
labels.append(label)
count += 1
if count == data_count:
break
else:
continue
break
else:
continue
break
else:
continue
break
end_time = dt.datetime.now()
print("time taken to generate data", end_time - start_time)
return images, labels
出现的错误在行:for f in font:
我在这里做错了什么?我必须使用 range() 吗?
font=cv2.FONT_HERSHEY_SIMPLEX
for f in font:
...
在 CV2 中,字体是代表字体本身的简单整数,我不是完全确定(a)为什么你正在尝试对其进行迭代。
如果您想遍历字体的 大小 ,则必须使用(例如)putText()
的 fontScale
参数。
如果您想迭代 字体集合 ,您必须提供该集合,例如以下之一:
font = [cv2.FONT_HERSHEY_SIMPLEX] # one font as a collection
font = [cv2.FONT_HERSHEY_SIMPLEX, cv2.FONT_HERSHEY_PLAIN] # two fonts
如果您只有 one 字体,则根本不要对其进行迭代。摆脱 for f in font
行(取消缩进当前“内部”的内容)并在当前使用 f
.
font
(a) Python 有 similar 麻烦试图弄清楚你的意图:-)