把Huggingface下载的arrow数据集转化为json格式

Arrow2json

使用默认的Huggingface路径

allenai/tulu-3-sft-mixture数据集为例。

使用load_dataset即可:

go 复制代码
from datasets import load_dataset

# 加载数据集
dataset = load_dataset("allenai/tulu-3-sft-mixture")

# 指定保存路径
output_dir = "~/xxx/open-instruct/data/tulu-3-sft-mixture-json"

# 将数据集转换为 JSON 格式
for split in dataset.keys():  # 处理所有划分 (train, validation 等)
    dataset[split].to_json(f"{output_dir}/{split}.json", orient="records", lines=True)

使用ls -sh输出可以看到数据集train.json大小是3.3GB

go 复制代码
3.3G train.json

从本地路径

本地路径如下:

查看一下文件大小:

go 复制代码
ls -sh ~/.cache/huggingface/datasets/allenai___tulu-3-sft-mixture-1024/train
total 1.2G
223M data-00000-of-00005.arrow  283M data-00002-of-00005.arrow  132M data-00004-of-00005.arrow
273M data-00001-of-00005.arrow  252M data-00003-of-00005.arrow  4.0K state.json

使用load_from_disk函数从本地路径加载

go 复制代码
from datasets import load_dataset, load_from_disk

# 加载数据集
dataset = load_from_disk("~/.cache/huggingface/datasets/allenai___tulu-3-sft-mixture-1024")

# 指定保存路径
output_dir = "~/xxx/open-instruct/data/tulu-3-sft-mixture-seqlen-1024-json"

# 将数据集转换为 JSON 格式
for split in dataset.keys():  # 处理所有划分 (train, validation 等)
    dataset[split].to_json(f"{output_dir}/{split}.json", orient="records", lines=True)

这样就可以转换为json了。

查看一下大小:

go 复制代码
ls -sh xxx/open-instruct/data/tulu-3-sft-mixture-seqlen-1024-json
total 1.3G
1.3G train.json

后记

2024年12月29日20点16分于上海.

相关推荐
wordbaby3 小时前
JSON.parse(JSON.stringify()) 的“坑”:数据丢失与类型转换问题
前端·json
还是鼠鼠8 小时前
Node.js局部生效的中间件
javascript·vscode·中间件·node.js·json·express
小石潭记丶9 小时前
sqlalchemy查询json
java·前端·json
欸呀呀呀1 天前
对象转成json后转成byte[]后在转成string会提示序列化失败,第一个字符是问号
后端·json
麓殇⊙1 天前
springMVC-Json交互处理
json·交互
还是鼠鼠1 天前
Node.js自定义中间件
javascript·vscode·中间件·node.js·json·express
懒惰的橘猫2 天前
mapreduce工作原理
json
我自纵横20232 天前
使用 JavaScript 动态设置 CSS 样式
开发语言·前端·javascript·css·html·json·html5
uyeonashi2 天前
【C++】从零实现Json-Rpc框架(2)
开发语言·c++·rpc·json
inxunoffice3 天前
按规则批量修改 txt/html/json/xml/csv/记事本等文本文件内容
xml·json