最近在微信公众号中看到有人用Python做了一个爬虫,可以将输入的英语单词翻译成中文,或者把中文词语翻译成英语单词。笔者看到了,觉得还蛮有意思的,因此,决定自己也写一个玩玩~~

  首先我们的爬虫要能将英语单词翻译成中文,因此,我们就需要一个网站帮助我们做这件事情。于是,我们选定有道词典,网址为: http://dict.youdao.com/ 。在该网页中我们输入单词nice,就会出来这个单词的意思,如下图:

![有道词典](https://img-blog.csdn.net/20180524133211564?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2pjbGlhbjkx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)

  针对上述过程,对于熟悉爬虫的读者来说,是不难完成将输入的单词的中文意思从网页中提取出来的。笔者的代码如下:
```
import requests
from bs4 import BeautifulSoup

get word from Command line

word = input("Enter a word (enter 'q' to exit): ")

main body

while word != 'q': # 'q' to exit

try:

# 利用GET获取输入单词的网页信息

r = requests.get(url='http://dict.youdao.com/w/%s/#keyfrom=dict2.top'%word)

# 利用BeautifulSoup将获取到的文本解析成HTML

soup = BeautifulSoup(r.text, "lxml")

# 获取字典的标签内容

s = soup.find(class_='trans-container')('ul')0

# 输出字典的具体内容

for item in s:

if item.text:

print(item.text)

print('='*40+'\n')

except Exception:

print("Sorry, there is a error!\n")

finally:

word = input( "Enter a word (enter 'q' to exit): ")

运行上述Python代码,结果如下:
<center>
![简单功能的实现](https://img-blog.csdn.net/20180524133923597?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2pjbGlhbjkx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)
</center>
&emsp;&emsp;上述过程无疑是简单的,下面,我们增加一些新的功能,如下: 1. 将Python代码打包成exe文件;
2. 在CMD中输出单词的中文意思时,输出为彩色文字。 &emsp;&emsp;利用ctypes模块,我们可以对Windows系统进行简单操作,而利用pyinstaller模块,我们可以将自己的Python代码打包成exe文件。
&emsp;&emsp;改修的Python代码如下:

import requests

from bs4 import BeautifulSoup

import random

import ctypes

STD_INPUT_HANDLE = -10

STD_OUTPUT_HANDLE = -11

STD_ERROR_HANDLE = -12

FOREGROUND_DARKBLUE = 0x01 # 暗蓝色

FOREGROUND_DARKGREEN = 0x02 # 暗绿色

FOREGROUND_DARKSKYBLUE = 0x03 # 暗天蓝色

FOREGROUND_DARKRED = 0x04 # 暗红色

FOREGROUND_DARKPINK = 0x05 # 暗粉红色

FOREGROUND_DARKYELLOW = 0x06 # 暗黄色

FOREGROUND_DARKWHITE = 0x07 # 暗白色

FOREGROUND_DARKGRAY = 0x08 # 暗灰色

FOREGROUND_BLUE = 0x09 # 蓝色

FOREGROUND_GREEN = 0x0a # 绿色

FOREGROUND_SKYBLUE = 0x0b # 天蓝色

FOREGROUND_RED = 0x0c # 红色

FOREGROUND_PINK = 0x0d # 粉红色

FOREGROUND_YELLOW = 0x0e # 黄色

FOREGROUND_WHITE = 0x0f # 白色

std_out_handle = ctypes.windll.kernel32.GetStdHandle(STD_OUTPUT_HANDLE)

设置文字颜色

def set_cmd_text_color(color, handle=std_out_handle):

Bool = ctypes.windll.kernel32.SetConsoleTextAttribute(handle, color)

return Bool

重置文字颜色为白色

def resetColor():

set_cmd_text_color(FOREGROUND_DARKWHITE)

以指定颜色输出文字

def cprint(mess, color):

color_dict = {'暗蓝色': FOREGROUND_DARKBLUE,

'暗绿色': FOREGROUND_DARKGREEN,

'暗天蓝色': FOREGROUND_DARKSKYBLUE,

'暗红色': FOREGROUND_DARKRED,

'暗粉红色': FOREGROUND_DARKPINK,

'暗黄色': FOREGROUND_DARKYELLOW,

'暗白色': FOREGROUND_DARKWHITE,

'暗灰色': FOREGROUND_DARKGRAY,

'蓝色': FOREGROUND_BLUE,

'绿色': FOREGROUND_GREEN,

'天蓝色': FOREGROUND_SKYBLUE,

'红色': FOREGROUND_RED,

'粉红色': FOREGROUND_PINK,

'黄色': FOREGROUND_YELLOW,

'白色': FOREGROUND_WHITE

}

set_cmd_text_color(color_dict[color])

print(mess)

resetColor()

颜色列表

color_list = ['暗蓝色','暗绿色','暗天蓝色','暗红色','暗粉红色','暗黄色','暗白色','暗灰色',

'蓝色','绿色','天蓝色','红色','粉红色','黄色','白色']

print information of this application

print('#'60)

print('This app is used for translating English word to Chineses!')

print('#'
60+'\n')

get word from Command line

word = input("Enter a word (enter 'q' to exit): ")

main body

while word != 'q': # 'q' to exit

try:

# 利用GET获取输入单词的网页信息

r = requests.get(url='http://dict.youdao.com/w/%s/#keyfrom=dict2.top'%word)

# 利用BeautifulSoup将获取到的文本解析成HTML

soup = BeautifulSoup(r.text, "lxml")

# 获取字典的标签内容

s = soup.find(class_='trans-container')('ul')0

# 随机选择输出的颜色

random.shuffle(color_list)

# 输出字典的具体内容

for item in s:

if item.text:

cprint(item.text, color_list[0])

print('='*40+'\n')

except Exception:

print("Sorry, there is a error!\n")

finally:

word = input( "Enter a word (enter 'q' to exit): ")

利用pyinstaller模块,将上述程序打包为exe文件。比如我们刚才的Python代码的文件名为English_2_Chinese_dict.py,位于E盘下的eng_2_chn文件夹下,我们可以在CMD中先切换到E盘下eng_2_chn文件夹,再输入以下命令:

pyinstaller -F English_2_Chinese_dict.py

这样就会生成一些文件,如下图:
<center>
![生成exe文件](https://img-blog.csdn.net/20180524134721286?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2pjbGlhbjkx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)
</center>
我们想要的生成的exe文件位于dist文件夹下,运行该exe文件,并测试,如下:
<center>
![exe文件测试](https://img-blog.csdn.net/20180524134940233?watermark/2/text/aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2pjbGlhbjkx/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70)
</center>
&emsp;&emsp;这样我们也就实现了上述新增的功能,能够更加方便地运行我们的程序。怎么样,是不是觉得Python爬虫酷酷的?不知作为新手的你,有没有一点心动呢?赶紧学起来吧,哈哈~~
&emsp;&emsp;本次分享到此结束,如有任何问题,请在下面评论哦~~ 注意:本人现已开通两个微信公众号: 因为Python(微信号为:python_math)以及轻松学会Python爬虫(微信号为:easy_web_scrape), 欢迎大家关注哦~~

Python爬虫之自制英汉字典的更多相关文章

  1. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(一)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  2. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(四)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  3. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(三)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  4. 【原创】shadowebdict开发日记:基于linux的简明英汉字典(二)

    全系列目录: [原创]shadowebdict开发日记:基于linux的简明英汉字典(一) [原创]shadowebdict开发日记:基于linux的简明英汉字典(二) [原创]shadowebdic ...

  5. 吴裕雄--天生自然python学习笔记:python 用firebase实现英汉词典进阶版

    用 post 方法创建的数据会自动产生一个 id (Key ),但有时也常常为了取得这个 id 而让程序难以处理 . 以英汉词典标准版来说,它的数据结构如下: 如果将每条数据都改为{eword:cwo ...

  6. python爬虫学习---爬取微软必应翻译(中英互译)

    前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:OSinooO 本人属于python新手,刚学习的 python爬虫基础 ...

  7. [Python爬虫笔记][随意找个博客入门(一)]

    [Python爬虫笔记][随意找个博客入门(一)] 标签(空格分隔): Python 爬虫 2016年暑假 来源博客:挣脱不足与蒙昧 1.简单的爬取特定url的html代码 import urllib ...

  8. Python爬虫个人记录(二) 获取fishc 课件下载链接

    参考: Python爬虫个人记录(一)豆瓣250 (2017.9.6更新,通过cookie模拟登陆方法,已成功实现下载文件功能!!) 一.目的分析 获取http://bbs.fishc.com/for ...

  9. 风变编程笔记(二)-Python爬虫精进

    第0关  认识爬虫 1. 浏览器的工作原理首先,我们在浏览器输入网址(也可以叫URL),然后浏览器向服务器传达了我们想访问某个网页的需求,这个过程就叫做[请求]紧接着,服务器把你想要的网站数据发送给浏 ...

随机推荐

  1. retrofit+rxjava封装

    public class RetrofitHelper { private static OkHttpClient okHttpClient; private static ServiceAPI se ...

  2. fiddler两种方式设置断点

    第一种:打开Fiddler 点击Rules-> Automatic Breakpoint  ->Before Requests(这种方法会中断所有的会话) 如何消除命令呢?  点击Rule ...

  3. SLAM算法中提取特征总结

    我们要知道三维空间中的点在图像中的位置,就需要提取特征与特征匹配了. 1.检测特征点 2.计算描述子 3.特征匹配 1.检测特征点 我们用到的检测特征点的方法是FAST算法,最大的特点就是快! 算法原 ...

  4. python基础自学 第三天

    变量的命名 01.标识符和关键字 标识符 标识符就是程序员定义的变量名.函数名. 标识符可以由字母,下划线,和数字组成. 不能以数字开头 不能与关键字重名 关键字 就是在python内部已经使用的标识 ...

  5. QEMU KVM libvirt手册(4) – images

    RAW raw是默认的格式,格式简单,容易转换为其他的格式.需要文件系统的支持才能支持sparse file 创建image # qemu-img create -f raw flat.img 10G ...

  6. FFmpeg开发实战(二):FFmpeg 文件操作

    FFmpeg 提供了丰富的API供我们使用,下面我们来讲述一下文件操作相关的API: FFmpeg 删除文件:avpriv_io_delete() FFmpeg 重命名文件:avpriv_io_mov ...

  7. 第68节:Java中的MYSQL运用从小白到大牛

    第68节:Java中的MYSQL运用从小白到大牛 前言 学习java必备要求,学会运用!!! 常见关系化数据库 BootStrap是轻量级开发响应式页面的框架,全局css组件,js插件.栅格系统是将页 ...

  8. Oracle merge合并更新函数

    本博客介绍一下Oracle merge合并函数,业务场景:新增数据的时候要先查询数据库是否已经有改数据,有数据就更新数据,没数据才新增数据,这是很常见的业务场景,如果是用Oracle数据库的话,其实直 ...

  9. python中os.path.isdir()等函数的作用和用法

    一 用法和概念: Python中的os模块用于和系统进行交互,其中: 1 os.listdir()用于返回一个由文件名和目录名组成的列表,需要注意的是它接收的参数需要是一个绝对的路径. 2 os.pa ...

  10. Docker 网络背后的原理探索

    本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫. 知其然而不知其 ...