File size: 1,493 Bytes
af6e330 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 |
import json
import random
def split_jsonl(input_file, output_file1, output_file2, split_ratio=0.8):
"""
将JSONL文件按比例拆分成两个不同的JSONL文件。
:param input_file: 输入的JSONL文件路径。
:param output_file1: 输出的第一个JSONL文件路径。
:param output_file2: 输出的第二个JSONL文件路径。
:param split_ratio: 第一个输出文件的数据比例(默认0.8)。
"""
# 读取JSONL文件
with open(input_file, 'r', encoding='utf-8') as infile:
lines = infile.readlines()
# 打乱数据
random.shuffle(lines)
# 计算分割点
split_point = int(len(lines) * split_ratio)
# 分割数据
lines1 = lines[:split_point]
lines2 = lines[split_point:]
# 写入第一个输出文件
with open(output_file1, 'w', encoding='utf-8') as outfile1:
for line in lines1:
outfile1.write(line)
# 写入第二个输出文件
with open(output_file2, 'w', encoding='utf-8') as outfile2:
for line in lines2:
outfile2.write(line)
# 示例使用
input_file = '/home/ubuntu/model_sft/ch/pubmedqa/data/ori_pqal_dealed.jsonl'
output_file1 = '/home/ubuntu/model_sft/ch/pubmedqa/data/train.jsonl'
output_file2 = '/home/ubuntu/model_sft/ch/pubmedqa/data/val.jsonl'
split_ratio = 0.8 # 80%的数据用于第一个文件,20%的数据用于第二个文件
split_jsonl(input_file, output_file1, output_file2, split_ratio)
|