您现在的位置是:首页 > 文章详情

浏览器插件实现GitHub代码翻译原型演示

日期:2019-05-08点击:327

此原型源自此想法: 中文化源码. 考虑到IDE插件工作量较大, 且与IDE绑定. 在代码转换工具的各种实现中, 综合考虑实用+易用+长远改进潜力, 浏览器插件似乎较有优势. 于是用最快捷的方式实现这一想法.

注: 此演示仅用Chrome在一个命名比较简单的代码页https://github.com/swaroopch/byte-of-python/blob/master/programs/ds_using_list.py 运行过, 限于取代码块的简单方式(取页面中的table元素)以及內建词典, 其他浏览器/github代码页的效果不保证.

原型项目源码在: program-in-chinese/webextension_github_code_translator

在Chrome下加载此插件后, 点击工具栏中的按钮(竟然默认图标是个'G', 也许是"Github代码翻译原型"的首字母). 弹窗中就会显示翻译后的代码段. 就这样:
2018_08_29_github_

项目源码节选

对代码段的文本进行简单替换:

function 翻译() { var 原代码拷贝 = document.getElementsByTagName('table')[0]; var span字段列表 = 原代码拷贝.getElementsByTagName('span'); 翻译字段列表(span字段列表); var 文本字段列表 = 取子文本节点(document); 翻译字段列表(文本字段列表); } function 取子文本节点(el) { var n, a = [], walk = document.createTreeWalker(el, NodeFilter.SHOW_TEXT, null, false); while (n = walk.nextNode()) a.push(n); return a; } // 假设每个字段除了词, 其他都是非英文字符. function 取字段中所有词(字段) { var 单词 = 字段.match(/[a-zA-Z]+/g); if (单词) { return 单词; } return [字段]; } function 取字段中最长句(字段) { var 句 = 字段.match(/[a-zA-Z\s]+/g); if (句 && 句.length > 0) { return 句[0].trim(); } return 字段; } function 翻译字段列表(字段列表) { for (var i = 0; i < 字段列表.length; i++) { var 字段 = 字段列表[i].textContent; var 所有单词 = 取字段中所有词(字段); var 所有单词有翻译 = false; for (var j = 0; j < 所有单词.length; j++) { var 单词 = 所有单词[j]; var 对应中文词 = 关键词词典[单词] || API词典[单词] || 命名词典[单词]; if (对应中文词) { if (j == 所有单词.length - 1) { 所有单词有翻译 = true; } } else { break; } 字段 = 字段.replace(单词, 对应中文词); } // 取巧: 仅当字段中所有词有翻译时才替换字段, 避免某些文本中出现个别可识别的单词. 今后需进行语法分析. if (所有单词有翻译) { 字段列表[i].textContent = 字段; } else { var 句 = 取字段中最长句(字段); var 对应中文 = 语句翻译[句.toLowerCase()] if (对应中文) { 字段列表[i].textContent = 字段.replace(句, 对应中文); } } } }

內建词典有几部分, 前两个(关键词/API)可扩展, 单词词汇可借助现有的英汉词典(olditem等还需另行拆分处理), 语句翻译可借助在线翻译API(原型中的翻译内容取自有道在线翻译):

var 关键词词典 = { 'for': '对于', 'in': '在', 'if': '如果', 'del': '删除' }; var API词典 = { 'print': '打印', 'append': '添加', 'sort': '排序', 'len': '长度', 'end': '结尾' } var 命名词典 = { 'shoplist': '购物单', 'apple': '苹果', 'mango': '芒果', 'carrot': '胡萝卜', 'banana': '香蕉', 'rice': '米', 'item': '物品', 'olditem': '第一项' } // 这里使用有道在线翻译结果. TODO: 用翻译API代替 var 语句翻译 = { 'this is my shopping list': '这是我的购物单', 'i have': '我有', 'items to purchase': '要购买的产品', 'i also have to buy rice': '我还得买大米', 'my shopping list is now': '我的购物单现在在', 'i will sort my list now': '我现在就整理我的清单', 'sorted shopping list is': '排序的购物清单是', 'the first item i will buy is': '我要买的第一件东西是' }

参考

Chrome Extension - Get DOM content

https://developer.chrome.com/extensions/tabs#method-executeScript

Find all text nodes in HTML page

中文关键词替换体验页面原型

为Chrome和火狐浏览器编写扩展

2018-08-29

原文链接:https://yq.aliyun.com/articles/701736
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章