File size: 1,945 Bytes
6f6ef66
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
46
47
48
49
50
51
import torch
from transformers import AutoTokenizer, AutoModelForCausalLM
import os
import json
from tqdm import tqdm

os.environ['CUDA_VISIBLE_DEVICES'] = '0'

current_path = os.path.dirname(os.path.abspath(__file__))

def replate_newline(text:str) -> str:
    return text.replace("\n","\\n")

if __name__ == '__main__':
    # アルパカ学習データの書式に合わせる
    # https://note.com/npaka/n/n91e6dfecd034

    # json file open
    json_open = open(current_path+"/train_data/databricks-dolly-15k-ja.json",'r', encoding="utf-8_sig")
    json_load = json.load(json_open)

    print(json_load[0])
    # 書き込み対象のdatabricks-dolly-15k-ja.txt open
    f = open(current_path+'/train_data/databricks-dolly-15k-ja.txt', 'w', encoding="utf-8_sig")

    for v in tqdm(json_load):
        string = r"<s>\n"
        if(v["input"]==""):
            # 入力がInstrcutionのみの場合
            string += r"以下は、タスクを説明する指示です。要求を適切に満たす応答を書きなさい。\n[SEP]\n"
            string += r"指示:\n"
            string += replate_newline(v["instruction"])
            string += r"\n[SEP]\n応答:\n"
            string += replate_newline(v["output"])
            string += r"\n</s>"
        else:
            # 入力がInstructionとInputの場合
            string += r"以下は、タスクを説明する指示と、文脈のある入力の組み合わせです。要求を適切に満たす応答を書きなさい。\n[SEP]\n"
            string += r"指示:\n"
            string += replate_newline(v["instruction"])
            string += r"\n[SEP]\n入力:\n"
            string += replate_newline(v["input"])
            string += r"\n[SEP]\n応答:\n"
            string += replate_newline(v["output"])
            string += r"\n</s>"
        # txtファイル書き込み
        f.write(string)
        f.write("\n")

    # txtを閉じる
    f.close()