列表 + 字典 + 向json文件追加数据

在关于图像的深度学习中,我们有图像和对应的标签。通常我们将图像名字和对应的标签写在json文件中,通过字典的方式进行编码。我们可以看一个例子:

[{"disease_class": 1, "image_id": "1.jpg"},

{"disease_class": 2, "image_id": "2.jpg"},

{"disease_class": 3, "image_id": "3.jpg"}]

注意到这个最外边是一个方括号,也就是说整个文件是一个列表的格式。

列表由很多的很多字典组成,每一个字典都包含两个键值对,一个是图片的标签,也就是groundtruth,这里就是disease_class,另一个就是图像的名字,这里就是image_id。

这样写是有好处的,我这里就不说是什么好处的。

本文首先给出如何读取这样的一个json文件:

```

    with open(validate_path, 'r') as load_f:

        load_dict = json.load(load_f)

        num_image = len(load_dict)

        for image in range(num_image):

            index = load_dict[image]["disease_class"]

            path = load_dict[image]['image_id']

            image_data = cv_imread(path)

```

主要用到了一个python库中函数:json 的json.load函数。然后采用列表的方式读取每一个图像的序列号,再进一步依据字典的键值对方式来索引具体的键值。

那么怎样才能创建这样的josn文件呢(从这个例子可以看书,并不是所有的json文件都是一样的,josn文件有它自己的组合方式,看官可以查看其它人的博客就知道,但愿你看完这篇文章之后能够找到你想要的json文件格式的制作)

上面说到,首先是列表,列表中是一个个的字典。

直接先上代码:

```

image_aug = [] # 先创建一个列表

image_path = 'AgriculturalDisease_trainingset'

root = os.getcwd()

path = os.path.join(root, 'new_train', 'new_train_labels.json')

# print(path)

with open(path, 'r') as f:

    load_dict = json.load(f)

    num_images = len(load_dict)

    for image in range(num_images):

        index = load_dict[image]["disease_class"]

        path = load_dict[image]["image_id"]

        image_dict = {"disease_class":index, "image_id":path}

        image_aug.append(image_dict) # 依据列表的append对文件进行追加

with open('new.json', 'w', encoding='utf-8') as file:

    json.dump(image_aug, file, ensure_ascii=False)

    # 最后根据json的dump将上面的列表写入文件,得到最终的json文件

```

总结为以下三步:

1)先创建一个列表

2)依据列表的append对文件进行追加

3)最后根据json的dump将上面的列表写入文件,得到最终的json文件

写到这里大家应该是比较理解怎么对json文件进行追加的吧。

实际上是利用列表进行追加。

你可能感兴趣的:(列表 + 字典 + 向json文件追加数据)