json_to_dataset.py 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. import argparse
  2. import base64
  3. import json
  4. import os
  5. import os.path as osp
  6. import imgviz
  7. import PIL.Image
  8. from labelme import utils
  9. from labelme.logger import logger
  10. def main():
  11. logger.warning(
  12. "DEPRECATED: This script will be removed in the near future. "
  13. "Please use `labelme_export_json` instead."
  14. )
  15. logger.warning(
  16. "NOTE: This script is aimed to demonstrate how to convert a JSON file "
  17. "to a single image dataset. so it won't handle multiple JSON files to "
  18. "generate a real-use dataset."
  19. )
  20. parser = argparse.ArgumentParser()
  21. parser.add_argument("json_file")
  22. parser.add_argument("-o", "--out", default=None)
  23. args = parser.parse_args()
  24. json_file = args.json_file
  25. if args.out is None:
  26. out_dir = osp.basename(json_file).replace(".", "_")
  27. out_dir = osp.join(osp.dirname(json_file), out_dir)
  28. else:
  29. out_dir = args.out
  30. if not osp.exists(out_dir):
  31. os.mkdir(out_dir)
  32. data = json.load(open(json_file))
  33. imageData = data.get("imageData")
  34. if not imageData:
  35. imagePath = os.path.join(os.path.dirname(json_file), data["imagePath"])
  36. with open(imagePath, "rb") as f:
  37. imageData = f.read()
  38. imageData = base64.b64encode(imageData).decode("utf-8")
  39. img = utils.img_b64_to_arr(imageData)
  40. label_name_to_value = {"_background_": 0}
  41. for shape in sorted(data["shapes"], key=lambda x: x["label"]):
  42. label_name = shape["label"]
  43. if label_name in label_name_to_value:
  44. label_value = label_name_to_value[label_name]
  45. else:
  46. label_value = len(label_name_to_value)
  47. label_name_to_value[label_name] = label_value
  48. lbl, _ = utils.shapes_to_label(img.shape, data["shapes"], label_name_to_value)
  49. label_names = [None] * (max(label_name_to_value.values()) + 1)
  50. for name, value in label_name_to_value.items():
  51. label_names[value] = name
  52. lbl_viz = imgviz.label2rgb(
  53. lbl, imgviz.asgray(img), label_names=label_names, loc="rb"
  54. )
  55. PIL.Image.fromarray(img).save(osp.join(out_dir, "img.png"))
  56. utils.lblsave(osp.join(out_dir, "label.png"), lbl)
  57. PIL.Image.fromarray(lbl_viz).save(osp.join(out_dir, "label_viz.png"))
  58. with open(osp.join(out_dir, "label_names.txt"), "w") as f:
  59. for lbl_name in label_names:
  60. f.write(lbl_name + "\n")
  61. logger.info("Saved to: {}".format(out_dir))
  62. if __name__ == "__main__":
  63. main()