Spaces:
Starting
on
T4
Starting
on
T4
import os | |
import tarfile | |
import datasets | |
import pandas as pd | |
_CITATION = """\ | |
@InProceedings{huggingface:dataset, | |
title = {Small htr examples images}, | |
author={Gabriel Borg}, | |
year={2023} | |
} | |
""" | |
_DESCRIPTION = """\ | |
Demo dataset for the htr demo. | |
""" | |
_HOMEPAGE = "https://huggingface.co/datasets/Riksarkivet/test_images_demo" | |
_LICENSE = "" | |
_REPO = "https://huggingface.co/datasets/Riksarkivet/test_images_demo" | |
class ExampleImages(datasets.GeneratorBasedBuilder): | |
"""Small sample of image-text pairs""" | |
def _info(self): | |
return datasets.DatasetInfo( | |
description=_DESCRIPTION, | |
features=datasets.Features( | |
{ | |
"text": datasets.Value("string"), | |
"image": datasets.Image(), | |
} | |
), | |
supervised_keys=None, | |
homepage=_HOMEPAGE, | |
citation=_CITATION, | |
) | |
def _split_generators(self, dl_manager): | |
images_archive = dl_manager.download(f"{_REPO}/resolve/main/images.tar.gz") | |
metadata_path = dl_manager.download(f"{_REPO}/resolve/main/images.txt") | |
image_iters = dl_manager.iter_archive(images_archive) | |
return [ | |
datasets.SplitGenerator( | |
name=datasets.Split.TRAIN, gen_kwargs={"images": image_iters, "metadata_path": metadata_path} | |
), | |
] | |
def _generate_examples(self, images, metadata_path): | |
"""Generate images and text.""" | |
with open(metadata_path, encoding="utf-8") as f: | |
metadata_list = f.read().split("\n") | |
for idx, (img_obj, meta_txt) in enumerate(zip(images, metadata_list)): | |
filepath, image = img_obj | |
text_value = meta_txt.split("= ")[-1].strip() | |
yield idx, { | |
"image": {"path": filepath, "bytes": image.read()}, | |
"text": text_value, | |
} | |
def txt_to_csv(file_name): | |
text_file_path = f"{file_name}.txt" | |
df = pd.read_csv(text_file_path, delimiter="=", header=None, names=["Key", "Label"], encoding="utf-8") | |
df["Key"] = df["Key"].str.strip() | |
df["Label"] = df["Label"].str.strip() | |
print(df) | |
df.to_csv(f"{file_name}.csv", index=False) | |
def sort_and_compress_images(images_folder, tar_file): | |
sorted_images = sorted(os.listdir(images_folder)) | |
with tarfile.open(tar_file, "w:gz") as tar: | |
for image_name in sorted_images: | |
image_path = os.path.join(images_folder, image_name) | |
tar.add(image_path, arcname=image_name) | |
print("Images sorted and compressed into tar.gz archive.") | |
if __name__ == "__main__": | |
txt_to_csv("info") | |
sort_and_compress_images("images", "sorted_images.tar.gz") | |