LangArea.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD018
  6. @NAME: langer
  7. @software: PyCharm
  8. @DATE: 2019/6/4 11:44
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: LangArea.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import json
  15. from django.http import HttpResponse
  16. from django.views.generic import TemplateView
  17. from django.views.decorators.csrf import csrf_exempt
  18. from django.utils.decorators import method_decorator
  19. from object.ResponseObject import ResponseObject
  20. from django.contrib.auth.hashers import make_password, check_password
  21. from model.models import UserModel, LangSetModel, LangAreaModel, LangValModel, LangKeyModel, LangKeyClassModel
  22. import time
  23. from object.TokenObject import TokenObject
  24. from django.http import StreamingHttpResponse
  25. class LangAreaView(TemplateView):
  26. def post(self, request, *args, **kwargs):
  27. request.encoding = 'utf-8'
  28. operation = kwargs.get('operation', None)
  29. request_dict = json.loads(request.body.decode('utf-8'))
  30. return self.validate(request_dict, operation)
  31. def get(self, request, *args, **kwargs):
  32. request.encoding = 'utf-8'
  33. request_dict = request.GET
  34. operation = kwargs.get('operation', None)
  35. return self.validate(request_dict, operation)
  36. def validate(self, request_dict, operation):
  37. response = ResponseObject()
  38. token = request_dict.get('token', None)
  39. tko = TokenObject(token)
  40. if tko.code == 0:
  41. userID = tko.userID
  42. user_qs = UserModel.objects.filter(id=userID, username='admin')
  43. if not user_qs.exists():
  44. return response.json(403)
  45. if operation == 'add':
  46. return self.do_add(request_dict, response)
  47. elif operation == 'update':
  48. return self.do_update(request_dict, response)
  49. elif operation == 'delete':
  50. return self.do_delete(request_dict, response)
  51. elif operation == 'query':
  52. return self.do_query(request_dict, response, userID)
  53. elif operation == 'export':
  54. return self.do_export(request_dict, response, userID)
  55. else:
  56. return response.json(414)
  57. else:
  58. return response.json(tko.code)
  59. def do_add(self, request_dict, response):
  60. lang = request_dict.get('lang', None)
  61. if lang:
  62. nowTime = int(time.time())
  63. create_dict = {
  64. 'lang': lang,
  65. 'addTime': nowTime,
  66. 'updTime': nowTime
  67. }
  68. try:
  69. LangAreaModel.objects.create(**create_dict)
  70. except Exception as e:
  71. return response.json(404, repr(e))
  72. else:
  73. return response.json(0)
  74. else:
  75. return response.json(414)
  76. def do_update(self, request_dict, response):
  77. lang = request_dict.get('lang', None)
  78. id = request_dict.get('id', None)
  79. nowTime = int(time.time())
  80. update_dict = {
  81. 'lang': lang,
  82. 'updTime': nowTime
  83. }
  84. try:
  85. LangAreaModel.objects.filter(id=id).update(**update_dict)
  86. except Exception as e:
  87. return response.json(404, repr(e))
  88. else:
  89. return response.json(0)
  90. def do_delete(self, request_dict, response):
  91. id = request_dict.get('id', None)
  92. try:
  93. LangAreaModel.objects.filter(id=id).delete()
  94. except Exception as e:
  95. return response.json(404, repr(e))
  96. else:
  97. return response.json(0)
  98. def do_query(self, request_dict, response, userID):
  99. user_qs = UserModel.objects.filter(id=userID, username='admin')
  100. if not user_qs.exists():
  101. return response.json(403)
  102. la_qs = LangAreaModel.objects.filter().values('lang', 'id')
  103. return response.json(0, list(la_qs))
  104. def do_export(self, request_dict, response, userID):
  105. print("进来了")
  106. id = request_dict.get('id', None)
  107. type = request_dict.get('type', None)
  108. # key_list = LangKeyModel.objects.filter().values_list('word_key', flat=True)
  109. print('id = ' + id)
  110. langType = (1, 3, 5, 7)
  111. if type == 'avss':
  112. langType = (2, 3, 6, 7)
  113. elif type == 'link_ios' or type == 'link_android':
  114. langType = (4, 5, 6, 7)
  115. en_qs = LangKeyModel.objects.filter(langvalmodel__la__id=20, type__in=langType).values('word_key', 'langvalmodel__word_val')
  116. en_kv = {}
  117. for e in en_qs:
  118. en_kv[e['word_key']] = e['langvalmodel__word_val']
  119. content = ''
  120. if type == 'ios' or type == 'link_ios':
  121. res_qs = LangKeyModel.objects.filter(langvalmodel__la__id=id, type__in=langType).\
  122. values('word_key', 'langvalmodel__word_val')
  123. res = {}
  124. for r in res_qs:
  125. print(r['langvalmodel__word_val'])
  126. if r['langvalmodel__word_val']:
  127. res[r['word_key']] = r['langvalmodel__word_val']
  128. elif en_kv[r['word_key']]:
  129. res[r['word_key']] = en_kv[r['word_key']]
  130. for l in res:
  131. content_val = res[l].replace('"', '\'')
  132. content = content + '"' + l + '"="' + content_val + '";\n'
  133. elif type == 'android' or type == 'link_android':
  134. res_qs = LangKeyModel.objects.filter(langvalmodel__la__id=id, type__in=langType).\
  135. values('word_key', 'langvalmodel__word_val').order_by('addTime')
  136. res = {}
  137. for r in res_qs:
  138. print(r['langvalmodel__word_val'])
  139. if r['langvalmodel__word_val']:
  140. res[r['word_key']] = r['langvalmodel__word_val']
  141. elif en_kv[r['word_key']]:
  142. res[r['word_key']] = en_kv[r['word_key']]
  143. for l in res:
  144. lk = l
  145. lk = lk.replace('.', '_')
  146. lk = lk.replace('\\n', '_')
  147. lk = lk.replace('“', '_')
  148. lk = lk.replace('”', '_')
  149. lk = lk.replace(' ', '_')
  150. lk = lk.replace('\\\'', '_')
  151. lk = lk.replace('\'', '_')
  152. lk = lk.replace('\\', '_')
  153. lk = lk.replace('!', '_')
  154. lk = lk.replace('’', '_')
  155. lk = lk.replace('...', '_')
  156. lk = lk.replace('…', '_')
  157. lk = lk.replace(':', '_')
  158. lk = lk.replace(':', '_')
  159. lk = lk.replace('(', '_')
  160. lk = lk.replace(')', '_')
  161. lk = lk.replace('?', '_')
  162. lk = lk.replace(',', '_')
  163. lk = lk.replace('-', '_')
  164. lk = lk.replace('%', '_')
  165. lk = lk.replace(';', '_')
  166. lk = lk.replace('‘', '_')
  167. # 正则表达式
  168. # re.sub("[a-z]+", "$", "123abc78ab9cdeg00t8")
  169. content_val = res[l].replace("'", "\\'")
  170. content_val = content_val.replace('"', '\\"')
  171. content = content + '<string name="' + lk + '">' + content_val + '</string>\n'
  172. elif type == 'avss':
  173. content = self.do_download_avss(id)
  174. response = StreamingHttpResponse(content)
  175. response['Content-Type'] = 'application/octet-stream'
  176. response['Content-Disposition'] = 'attachment;filename="lang.txt"'
  177. return response
  178. return response.json(0, res)
  179. def do_download_avss(self, id):
  180. content = ''
  181. en_result = self.get_area_language(20)
  182. target_result = self.get_area_language(id)
  183. if target_result:
  184. content += '<TS version=\"2.1\" language=\"' + self.get_avss_language(int(id)) + '\">\n'
  185. # keys = result.keys()
  186. keys = en_result.keys()
  187. for key in keys:
  188. content += '<context>\n<name>'
  189. content += key
  190. content += '</name>\n'
  191. messages = None
  192. if target_result.__contains__(key):
  193. messages = target_result[key]
  194. else:
  195. messages = en_result[key]
  196. messageKeys = en_result[key].keys()
  197. for messageKey in messageKeys:
  198. message = None
  199. if messages.__contains__(messageKey):
  200. message = messages[messageKey]
  201. else:
  202. message = en_result[key][messageKey]
  203. # message = messages[messageKey]
  204. content += '<message>\n'
  205. content += '<source>'
  206. content += message['source']
  207. content += '</source>\n'
  208. content += '<translation>'
  209. translation = message['translation']
  210. # if translation is None or translation == '':
  211. # content += '23333'
  212. # else:
  213. content += translation
  214. content += '</translation>\n'
  215. locations = message['locations']
  216. print(message)
  217. for location in locations:
  218. if location['filename'] != '':
  219. content += '<location filename=\"' + location['filename'] + '\" line=\"' + str(location['line']) + '\"/>\n'
  220. content += '</message>\n'
  221. content += '</context>\n'
  222. content += '</TS>'
  223. return content
  224. else:
  225. print('none')
  226. return content
  227. def get_area_language(self, id):
  228. result = {}
  229. lkc_qs = LangKeyModel.objects.filter(langvalmodel__la__id=id, type__in=(2, 3, 6, 7)).values('word_key',
  230. 'langkeyclassmodel__clazz__name',
  231. 'langvalmodel__word_val',
  232. 'langlocationmodel__filename',
  233. 'langlocationmodel__line')
  234. for lkc in lkc_qs:
  235. # print(lkc)
  236. name = lkc['langkeyclassmodel__clazz__name']
  237. hasClass = result.__contains__(name)
  238. if hasClass is False:
  239. result[name] = {}
  240. source = lkc['word_key']
  241. if not result[name].__contains__(source):
  242. result[name][source] = {}
  243. message = result[name][source]
  244. message['source'] = source
  245. message['translation'] = lkc['langvalmodel__word_val']
  246. # location
  247. locations = []
  248. locations.append({'filename': lkc['langlocationmodel__filename'], 'line': lkc['langlocationmodel__line']})
  249. message['locations'] = locations
  250. print(result)
  251. return result
  252. def get_avss_language(self, id):
  253. if id == 18: # 简体中文
  254. return 'zh_CN'
  255. elif id == 19: # 繁体中文
  256. return 'zh_HK'
  257. elif id == 20: # 英文
  258. return 'en_US'
  259. elif id == 21: # 俄语
  260. return 'ru'
  261. elif id == 22: # 德语
  262. return 'de'
  263. elif id == 23: # 波兰语
  264. return 'pl'
  265. elif id == 24: # 法语
  266. return 'fr'
  267. elif id == 25: # 西班牙语
  268. return 'es'
  269. elif id == 26: # 日语
  270. return 'ja'
  271. elif id == 27: # 阿拉伯语
  272. return 'ar'
  273. elif id == 29: # 意大利语
  274. return 'it'
  275. elif id == 30: # 葡萄牙语
  276. return 'pt'
  277. elif id == 31: # 荷兰语
  278. return 'nl'
  279. elif id == 32: # 越南语
  280. return 'vi'
  281. else:
  282. return 'en'
  283. class exportLangView(TemplateView):
  284. def post(self, request, *args, **kwargs):
  285. request.encoding = 'utf-8'
  286. request_dict = json.loads(request.body.decode('utf-8'))
  287. return self.validate(request_dict)
  288. def get(self, request, *args, **kwargs):
  289. request.encoding = 'utf-8'
  290. request_dict = request.GET
  291. return self.validate(request_dict)
  292. def validate(self, request_dict):
  293. # 得到即将下载文件的路径和名称
  294. response = StreamingHttpResponse('123l4kjlkfjlksadjlfksdajlf')
  295. response['Content-Type'] = 'application/octet-stream'
  296. response['Content-Disposition'] = 'attachment;filename="lang.txt"'
  297. return response