Merge pull request #135 from JavanZhu/master

Improvement and bug fixed
This commit is contained in:
sthoo 2019-04-07 15:12:53 +08:00 committed by GitHub
commit 18c87bc413
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 59 additions and 23 deletions

3
.gitignore vendored
View File

@ -116,3 +116,6 @@ User*/
release*.zip
README.txt
.fastwq_*_ankihub.json
# idea ide
/.idea

View File

@ -100,7 +100,9 @@ _arr = [
['DEF', u'释义', u'Definition'],
['PHON', u'音标', u'Phonetic Symbols'],
['BRE_PHON', u'英式音标', u'Phonetic Symbols (UK)'],
['BRE_PHON_NO_PREFIX', u'英式音标无前缀', u'Phonetic Symbols (UK) no prefix'],
['AME_PHON', u'美式音标', u'Phonetic Symbols (US)'],
['AME_PHON_NO_PREFIX', u'美式音标无前缀', u'Phonetic Symbols (US) no prefix'],
['IMAGE', u'图片', u'Images'],
]

View File

@ -1,4 +1,4 @@
#-*- coding:utf-8 -*-
# -*- coding:utf-8 -*-
import os
import re
@ -6,7 +6,6 @@ from bs4 import Tag
from ..base import *
from ...utils.misc import format_multi_query_word
longman_download_mp3 = True
longman_download_img = True
@ -30,8 +29,8 @@ class Longman(WebService):
assert isinstance(dic_link, Tag)
# remove sound tag
am_s_tag = dic_link.find('span', title='Play American pronunciation of {}'.format(self.word))
br_s_tag = dic_link.find('span', title='Play British pronunciation of {}'.format(self.word))
am_s_tag = dic_link.find('span', {'class': 'speaker amefile fa fa-volume-up hideOnAmp'})
br_s_tag = dic_link.find('span', {'class': 'speaker brefile fa fa-volume-up hideOnAmp'})
if am_s_tag:
word_info['am_mp3'] = am_s_tag.get('data-src-mp3', u'')
am_s_tag.decompose()
@ -91,7 +90,7 @@ class Longman(WebService):
word_info['pos'] = POS
word_info['inflections'] = Inflections
head_finded = True
#self.cache_this(word_info)
# self.cache_this(word_info)
if head_tag:
head_tag.decompose()
@ -118,7 +117,7 @@ class Longman(WebService):
@export('PHON')
def fld_phonetic(self):
return self._get_field('phonetic')
def _fld_mp3(self, fld):
audio_url = self._get_field(fld)
if longman_download_mp3 and audio_url:

View File

@ -1,5 +1,5 @@
# coding=utf-8
#from warnings import filterwarnings
# from warnings import filterwarnings
from bs4 import Tag
from ..base import *
@ -14,7 +14,7 @@ import sys
@register([u'牛津学习词典', u'Oxford Learner'])
class OxfordLearning(WebService):
def __init__(self):
super(OxfordLearning, self).__init__()
@ -42,9 +42,11 @@ class OxfordLearning(WebService):
if web_word:
self.cache_this(
{
'phonetic': '{} {}'.format(web_word.wd_phon_bre, web_word.wd_phon_nam),
'phonetic': '{} {}'.format(web_word.wd_phon_bre, web_word.wd_phon_ame),
'phon_bre': '{}'.format(web_word.wd_phon_bre),
'phon_ame': '{}'.format(web_word.wd_phon_nam),
'phon_ame': '{}'.format(web_word.wd_phon_ame),
'phon_bre_no_prefix': '{}'.format(web_word.wd_phon_bre_no_prefix),
'phon_ame_no_prefix': '{}'.format(web_word.wd_phon_ame_no_prefix),
'pos': web_word.wd_pos,
'img_full': web_word.wd_image_full_url,
'img_thumb': web_word.wd_image_thumb_url,
@ -81,6 +83,14 @@ class OxfordLearning(WebService):
def fld_phonetic_uk(self):
return self._get_single_dict('phon_bre')
@export('BRE_PHON_NO_PREFIX')
def fld_phonetic_us_no_prefix(self):
return self._get_single_dict('phon_bre_no_prefix')
@export('AME_PHON_NO_PREFIX')
def fld_phonetic_uk_no_prefix(self):
return self._get_single_dict('phon_ame_no_prefix')
@export([u'词性', u'POS'])
def fld_pos(self):
return self._get_single_dict('pos')
@ -211,24 +221,35 @@ class OxfordLearningDictWord:
# endregion
def _pull_bre_phon(self):
try:
_tag_phn = self.tag_phon_bre.find('span', self._cls_dic('phon')).get_text().replace('/', '').replace('BrE', '')
phon = '/{}/'.format(_tag_phn.text if isinstance(_tag_phn, Tag) else _tag_phn)
except:
phon = ''
return phon
@property
def wd_phon_bre_no_prefix(self):
"""
:return: phon
"""
return self._pull_bre_phon()
@property
def wd_phon_bre(self):
"""
:return: pre_fix, phon
"""
try:
_tag_phn = self.tag_phon_bre.find('span', self._cls_dic('phon')).contents[3]
phon = '/{}/'.format(_tag_phn.text if isinstance(_tag_phn, Tag) else _tag_phn)
except:
phon = ''
try:
prefix = self.tag_phon_bre.find('span', self._cls_dic('prefix')).string
except:
prefix = ''
return "{} {}".format(
prefix,
phon
self._pull_bre_phon()
)
@property
@ -238,24 +259,35 @@ class OxfordLearningDictWord:
except:
return ''
def _pull_ame_phon(self):
try:
_tag_phn = self.tag_phon_nam.find('span', self._cls_dic('phon')).get_text().replace('/', '').replace('NAmE', '')
phon = '/{}/'.format(_tag_phn.text if isinstance(_tag_phn, Tag) else _tag_phn)
except:
phon = ''
return phon
@property
def wd_phon_nam(self):
def wd_phon_ame_no_prefix(self):
"""
:return: phon
"""
return self._pull_ame_phon()
@property
def wd_phon_ame(self):
"""
:return: pre_fix, phon
"""
try:
_tag_phn = self.tag_phon_nam.find('span', self._cls_dic('phon')).contents[3]
phon = '/{}/'.format(_tag_phn.text if isinstance(_tag_phn, Tag) else _tag_phn)
except:
phon = ''
try:
prefix = self.tag_phon_nam.find('span', self._cls_dic('prefix')).string
except:
prefix = ''
return "{} {}".format(
prefix,
phon
self._pull_ame_phon()
)
@property