Capture de forma remota los resultados de traducción automática de GOOGLE
Autor:Eve Cole
Fecha de actualización:2009-07-01 16:08:47
1 Función RemoveHTML()Función RemoveHTML(strhtml)
2 si strhtml<>"" entonces
3 tenue s_str como cadena
4 s_str=regex.replace(strHTML,"<[^>]+>","")
5 s_str=reemplazar(s_str," ","")
6 retorno s_str
7 terminar si
8 Función final
9
10 Función china_to_english()Función china_to_english(textos,idiomas)
11 Carga útil atenuada como cadena = "hl=zh-CN&ie=UTF8&text="& texts &"&langpair="& idiomas &""
12 dim str_return como cadena
13 Dim req As WebRequest = WebRequest.Create(" http://translate.google.com/translate_t ") ' 开始取连接.
14 req.Credentials = CredentialCache.DefaultCredentials '取得默认
15 req.Method = "POST" '以POST方式发送,这里默认是以GET方式发送
16 req.ContentType = "application/x-www-form-urlencoded" 'POST方式需在传送这个编码,如果上传文件,则修为multipart/form-data
17 req.timeout=10000 '连接超时定时
18 req.ContentLength = carga útil.Length '头部长度
19 Codificación tenue Como codificación = Codificación.GetEncoding("UTF-8") '转换成流,大部网站一般转换成UTF-8就可以了,注意是大写的编码
20 bytes tenues As Byte() = Encoding.GetBytes(carga útil) '转换成流
21 req.ContentLength = bytes.Length '传送流的长度
22 Dim newStream As Stream = req.GetRequestStream() '转换写入
23 newStream.Write(bytes, 0, bytes.Longitud) '写入传送流
24 newStream.Close() '关闭
25 '上面发送完成,下面取得服务器返回
26 Dim res As HttpWebResponse = CType(req.GetResponse(), HttpWebResponse) ' 传递返回标识
27 si res.StatusDescription="ok" entonces ' 返回取得状态.
28 respuesta.actual.escritura("暂时无法连接到网站,请换用另一个程序")
29 respuesta.actual.fin()
30 final si
31 Dim dataStream As Stream = res.GetResponseStream() ' 返回给指针
32 Lector atenuado como nuevo StreamReader(dataStream,encoding.getencoding("gb2312")) ' 读
33 Dim ResponseFromServer As String = lector.ReadToEnd() ' 读取所有
34
35 str_return=responseFromServer '赋值回传
36
37 lector.Close() '接下来三个关闭
38 flujo de datos.Cerrar()
39 res.Cerrar()
40
41 dim ss como cadena = str_return
42 ss = regex.replace(ss,"(?i:(.+)(<div)(.+)(>)(.+)(</div>)(.+))" ,"$5") '提取我们所要的译文
43 ss = EliminarHTML(ss) '删除HTML
44 ss = ss.substring(3) '删除翻译二字
45 retorno ss '函数返回
46 Función final
47
48 在调用china_to_english(textos,idiomas)需要传两个参数第一个为要译的文字,第二个是要进行相对译的语种代码.
例:中译英,其第二个参数为:zh-Cn|en
我导入的命名空间如下:
Sistema de Importaciones
Sistema de Importaciones.Web
Importaciones System.IO
Importa Microsoft.VisualBasic
Importaciones System.Web.HttpContext
Importaciones System.Web.UI
Importaciones System.Web.UI.WebControls
Sistema de importaciones.Texto
Importaciones System.Text.RegularExpressions
Importaciones System.Net