Skip to main content

Tool to work with annotation formats

Project description

pascal

Python utility to work with PascalVoc annotation format

Image examples from PascalVoc2007 dataset

Code Example
import json
from pathlib import Path

from PIL import Image

from pascal import annotation_from_xml
from pascal.utils import save_xml

ds_path = Path("/home/VOCtest_06-Nov-2007/VOCdevkit/VOC2007")

img_src = ds_path / "JPEGImages"
ann_src = ds_path / "Annotations"

out_labelme = ds_path / "converted_labelme"

attr_type_spec = {"truncated": bool, "difficult": bool}

label_map = {"car": 1, "dog": 0, "person": 2, "train": 3}

if __name__ == "__main__":
    for file in img_src.glob("*.jpg"):
        # Get annotation file path
        ann_file = (ann_src / file.name).with_suffix(".xml")
        # Make pascal annotation object
        ann = annotation_from_xml(ann_file, attr_type_spec)
        print(ann)
        # Save to xml file (same as ann_file)
        xml = ann.to_xml()
        out_xml_name = file.with_suffix(".xml").name
        save_xml(out_xml_name, xml)
        # Save yolo annotation
        yolo_ann = ann.to_yolo(label_map)
        out_yolo_name = file.with_suffix(".txt").name
        with open(out_yolo_name, "w") as f:
            f.write(yolo_ann)
        # Convert to labelme and save json file
        res = ann.to_labelme(file, save_img_data=False)
        with open((out_labelme / file.name).with_suffix(".json"), "w") as f:
            json.dump(res, f, indent=2)
        # Draw objects
        img = Image.open(file)
        draw_img = ann.draw_boxes(img)
        draw_img.show()
Visualization example:
draw_img = ann.draw_boxes(img)
draw_img.show()

vis_example

Installation

From source

python setup.py install

Using pip

pip install pascal-voc

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pascal_voc-2.1.11.tar.gz (220.9 kB view details)

Uploaded Source

Built Distribution

pascal_voc-2.1.11-py3-none-any.whl (427.6 kB view details)

Uploaded Python 3

File details

Details for the file pascal_voc-2.1.11.tar.gz.

File metadata

  • Download URL: pascal_voc-2.1.11.tar.gz
  • Upload date:
  • Size: 220.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for pascal_voc-2.1.11.tar.gz
Algorithm Hash digest
SHA256 0409f323a861acf1f19d5591eb99bb709d34bb87dac2997f958a768e22be7c44
MD5 b436d491a9c91b1a2dbe59410368ec5c
BLAKE2b-256 1ea891c6b706fdc319257300f767c9ac0d42242d0638f20b64440f80fb53142b

See more details on using hashes here.

File details

Details for the file pascal_voc-2.1.11-py3-none-any.whl.

File metadata

  • Download URL: pascal_voc-2.1.11-py3-none-any.whl
  • Upload date:
  • Size: 427.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for pascal_voc-2.1.11-py3-none-any.whl
Algorithm Hash digest
SHA256 849f5b5b3725fe09fe1831573d618a544b75b2981ce02d4931bfd82930b57e6d
MD5 629238622030ec4b83a5a4fbb77c7484
BLAKE2b-256 3500d6f1891fa6960d5b53cbdc46a2947b494adaf672f2593cea5ea2f4125582

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page