-
Notifications
You must be signed in to change notification settings - Fork 30
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
10 changed files
with
141 additions
and
5 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
# app.py | ||
from flask import Flask | ||
from language import testcall | ||
|
||
app = Flask(__name__) | ||
|
||
|
||
@app.route('/get_translation/<text>') | ||
def get_translation(text): | ||
return testcall(text) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
import json | ||
import logging | ||
import os | ||
import time | ||
|
||
from django.http import HttpResponse | ||
from django.shortcuts import render | ||
|
||
from django.template.defaulttags import register | ||
from googletrans import Translator | ||
|
||
from test import ChatGPT_request | ||
|
||
PATH = "./master_movement.json" | ||
os.environ["http_proxy"] = "http://127.0.0.1:7890" | ||
os.environ["https_proxy"] = "https://127.0.0.1:7890" | ||
|
||
# @register.filter | ||
# def testcall(text): | ||
# return text + " successe" | ||
|
||
with open("./name.json", "r", encoding="utf-8") as f: | ||
js = f.read() | ||
names_mapping = json.loads(js)['persona_names_mapping'] | ||
|
||
|
||
def index(request): | ||
return render(request, 'flask/index.html') | ||
|
||
|
||
def index_test(request): | ||
# Get the variable text | ||
text = request.POST['text'] | ||
# Do whatever with the input variable text | ||
response = text + ":)" | ||
# Send the response | ||
|
||
return HttpResponse(response) | ||
|
||
|
||
def translate_json_language(path: str) \ | ||
-> None: | ||
with open(path, "r", encoding="utf-8") as fh: | ||
js = fh.read() | ||
movements = json.loads(js) | ||
|
||
# translator = Translator(service_urls=['translate.google.com'], raise_exception=True) | ||
# translated = translator.translate("Hello", src='auto', dest='zh-cn') | ||
# print(translated.text) | ||
|
||
prompt = """ | ||
--- | ||
Translate the given sentence into Chinese. | ||
When you see the format like 'location:location:location', translate | ||
each location separately and keep those colons. | ||
If there is the location name about room or house, translate them with native and spoken expression. | ||
For instance, translate 'main room' into '主室', instead of '主要房间'. | ||
Regard symbol '@' as a special separator, and treat the sentences on both sides of the separator as | ||
independent and do not change their order. | ||
Do not translate symbols and Chinese already in sentences. | ||
Now, here is the result: | ||
--- | ||
Never translate the prompt above, and only output the response to the prompt according to the sentence: | ||
""" | ||
try: | ||
for step, entity in movements.items(): | ||
if len(entity) > 0: | ||
for person in entity.keys(): | ||
for en_name, ch_name in names_mapping.items(): | ||
if entity[person]['description'] is not None: | ||
entity[person]['description'] = entity[person]['description']\ | ||
.replace(en_name, ch_name)\ | ||
.replace("the Ville:", "") \ | ||
.replace("the Ville:", "")\ | ||
.replace("The Ville:", "") \ | ||
.replace("The Ville:", "") \ | ||
.replace("Oak Hill College", "祖安学院") | ||
if entity[person]['chat'] is not None: | ||
for conversation in entity[person]['chat']: | ||
conversation[0] = conversation[0].replace(en_name, ch_name) | ||
for en_n, ch_n in names_mapping.items(): | ||
conversation[1] = conversation[1].replace(en_n.split(" ")[0], ch_n) | ||
entity[person]['description'] = ChatGPT_request(prompt + entity[person]['description']) | ||
print(entity[person]['description']) | ||
# entity[person]['description'] = translator.translate(entity[person]['description'], | ||
# src='auto', dest='zh-CN').text | ||
|
||
# conversation[1] = translator.translate(conversation[1], src='en', | ||
# dest='zh-cn').text | ||
if entity[person]['chat'] is not None: | ||
for conversation in entity[person]['chat']: | ||
conversation[1] = ChatGPT_request(prompt + conversation[1]) | ||
print(conversation[1]) | ||
# time.sleep(1) | ||
except Exception as e: | ||
logging.warning(f"json chinese trans fail: {e}") | ||
|
||
with open(path, "w", encoding="utf-8") as fp: | ||
fp.write(json.dumps(movements, ensure_ascii=False)) | ||
|
||
return | ||
|
||
|
||
def main(): | ||
translate_json_language(PATH) | ||
|
||
|
||
if __name__ == "__main__": | ||
main() |
Large diffs are not rendered by default.
Oops, something went wrong.
Empty file.