Python TypeError:Int对象不可编辑

Python TypeError:Int对象不可编辑,python,python-3.7,Python,Python 3.7,我正在尝试使用不同的字体为OCR生成数据集,但在某个for循环中,迭代给我和errorTypeerror:int对象是不可编辑的。 我已经搜索了足够多的内容,得出结论,StackOverFlow上的大多数答案都建议使用for循环中的范围,包括(len),但我不确定是否遵循了该范围 功能如下: def gen_rand_string_data(data_count, min_char_count=3, max_ch

我正在尝试使用不同的字体为OCR生成数据集,但在某个for循环中,迭代给我和error
Typeerror:int对象是不可编辑的。
我已经搜索了足够多的内容,得出结论,StackOverFlow上的大多数答案都建议使用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
引发的错误位于字体中f的第行:

我做错了什么?我必须使用range()吗

在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
如果您只有一种字体,那么根本不要对其进行迭代。在font行中去掉f的
(取消当前在其中的内容),只要在当前使用
f
的地方使用
font



(a) Python在试图找出您的意图时也遇到了类似的问题:-)

您是否使用
范围
进行了尝试?在
错误
行发布完整的错误是。
font = [cv2.FONT_HERSHEY_SIMPLEX]                         # one font as a collection
font = [cv2.FONT_HERSHEY_SIMPLEX, cv2.FONT_HERSHEY_PLAIN] # two fonts