看到不错的东西,记录下。linux 单词翻译小程序
1.python:命令:Python Translate.py computer
类库(urllib,BeautifulSoup ),前者主要负责网络通讯方面,后者负责HTML的解析。
2.shell:
wget:
-q表示关闭请求过程中的状态输出,只显示响应的内容。
-O - 表示把响应的内容写到stdout,而不是文件,如果用 -O mfile.html 就表示保存到文件myfile.html
一般上面两个参数会合起来写成-qO-
sed:
-E选项表示使用扩展的正则表达式。
1.python:命令:Python Translate.py computer
类库(urllib,BeautifulSoup ),前者主要负责网络通讯方面,后者负责HTML的解析。
import urllib
import codecs
from BeautifulSoup import BeautifulSoup
from sys import argv
import re,time
class Translate:
def Start(self):
self._get_html_sourse()
self._get_content("enc")
self._remove_tag()
self.print_result()
def _get_html_sourse(self):
word=argv[1] if len(argv)>1 else ''
url="http://dict.baidu.com/s?wd=%s&tn=dict" % word
self.htmlsourse=unicode(urllib.urlopen(url).read(),"gb2312","ignore").encode("utf-8","ignore")
def _get_content(self,div_id):
soup=BeautifulSoup("".join(self.htmlsourse))
self.data=str(soup.find("div",{"id":div_id}))
def _remove_tag(self):
soup=BeautifulSoup(self.data)
self.outtext=''.join([element for element in soup.recursiveChildGenerator() if isinstance(element,unicode)])
def print_result(self):
for item in range(1,10):
self.outtext=self.outtext.replace(str(item),"\n%s" % str(item))
self.outtext=self.outtext.replace(" ","\n")
print self.outtext
if __name__=="__main__":
Translate().Start()
2.shell:
translate() {
wget -qO- "http://ajax.googleapis.com/ajax/services/language/translate?v=1.0&q=$1&langpair=${2:-en}|${3:-zh}" | sed -E -n 's/[[:alnum:]": {}]+"translatedText":"([^"]+)".*/\1/p';
return 0;
}
放到你的~/.bashrc或者~/.zshrc里面 执行$ translate hello。
wget:
-q表示关闭请求过程中的状态输出,只显示响应的内容。
-O - 表示把响应的内容写到stdout,而不是文件,如果用 -O mfile.html 就表示保存到文件myfile.html
一般上面两个参数会合起来写成-qO-
sed:
-E选项表示使用扩展的正则表达式。