88 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
#-*- coding:utf-8 -*-
 | 
						|
import re
 | 
						|
from ..base import *
 | 
						|
from ...context import config
 | 
						|
 | 
						|
 | 
						|
VOICE_PATTERN = r'<a href="sound://([\w/]+\w*\.mp3)"><img src="img/spkr_%s.png"></a>'
 | 
						|
MAPPINGS = [
 | 
						|
    ['br', [re.compile(VOICE_PATTERN % r'r')]],
 | 
						|
    ['us', [re.compile(VOICE_PATTERN % r'b')]]
 | 
						|
]
 | 
						|
LANG_TO_REGEXPS = {lang: regexps for lang, regexps in MAPPINGS}
 | 
						|
 | 
						|
 | 
						|
@register([u'本地词典-LDOCE6', u'MDX-LDOCE6'])
 | 
						|
class Ldoce6(MdxService):
 | 
						|
 | 
						|
    def __init__(self):
 | 
						|
        super(Ldoce6, self).__init__(config.LDOCE6_PATH)
 | 
						|
 | 
						|
    @property
 | 
						|
    def title(self):
 | 
						|
        return getattr(self, '__register_label__', self.unique)
 | 
						|
 | 
						|
    @export('PHON')
 | 
						|
    def fld_phonetic(self):
 | 
						|
        html = self.get_html()
 | 
						|
        m = re.search(r'<span class="pron">(.*?)</span>', html)
 | 
						|
        if m:
 | 
						|
            return m.groups()[0]
 | 
						|
        return ''
 | 
						|
 | 
						|
    def _fld_voice(self, html, voice):
 | 
						|
        """获取发音字段"""
 | 
						|
        for regexp in LANG_TO_REGEXPS[voice]:
 | 
						|
            match = regexp.search(html)
 | 
						|
            if match:
 | 
						|
                val = '/' + match.group(1)
 | 
						|
                name = get_hex_name('mdx-'+self.unique.lower(), val, 'mp3')
 | 
						|
                name = self.save_file(val, name)
 | 
						|
                if name:
 | 
						|
                    return self.get_anki_label(name, 'audio')
 | 
						|
        return ''
 | 
						|
 | 
						|
    @export('BRE_PRON')
 | 
						|
    def fld_voicebre(self):
 | 
						|
        return self._fld_voice(self.get_html(), 'br')
 | 
						|
 | 
						|
    @export('AME_PRON')
 | 
						|
    def fld_voiceame(self):
 | 
						|
        return self._fld_voice(self.get_html(), 'us')
 | 
						|
 | 
						|
    @export('EXAMPLE')
 | 
						|
    def fld_sentence(self):
 | 
						|
        m = re.findall(r'<span class="example"\s*.*>\s*.*<\/span>', self.get_html())
 | 
						|
        if m:
 | 
						|
            soup = parse_html(m[0])
 | 
						|
            el_list = soup.findAll('span', {'class':'example'})
 | 
						|
            if el_list:
 | 
						|
                maps = [u''.join(str(content) for content in element.contents) 
 | 
						|
                                    for element in el_list]
 | 
						|
            my_str = ''
 | 
						|
            for i_str in maps:
 | 
						|
                i_str = re.sub(r'<a[^>]+?href=\"sound\:.*\.mp3\".*</a>', '', i_str)
 | 
						|
                i_str = i_str.replace(' ', '')
 | 
						|
                my_str = my_str + '<li>' + i_str + '</li>'
 | 
						|
            return self._css(my_str)
 | 
						|
        return ''
 | 
						|
 | 
						|
    @export('DEF')
 | 
						|
    def fld_definate(self):
 | 
						|
        m = m = re.findall(r'<span class="def"\s*.*>\s*.*<\/span>', self.get_html())
 | 
						|
        if m:
 | 
						|
            soup = parse_html(m[0])
 | 
						|
            el_list = soup.findAll('span', {'class':'def'})
 | 
						|
            if el_list:
 | 
						|
                maps = [u''.join(str(content) for content in element.contents) 
 | 
						|
                                    for element in el_list]
 | 
						|
            my_str = ''
 | 
						|
            for i_str in maps:
 | 
						|
                my_str = my_str + '<li>' + i_str + '</li>'
 | 
						|
            return self._css(my_str)
 | 
						|
        return ''
 | 
						|
 | 
						|
    @with_styles(cssfile='_ldoce6.css')
 | 
						|
    def _css(self, val):
 | 
						|
        return val
 | 
						|
     |