當前位置: 首頁>>代碼示例>>Python>>正文


Python html.unescape方法代碼示例

本文整理匯總了Python中html.unescape方法的典型用法代碼示例。如果您正苦於以下問題:Python html.unescape方法的具體用法?Python html.unescape怎麽用?Python html.unescape使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在html的用法示例。


在下文中一共展示了html.unescape方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: write_voiceactivity

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def write_voiceactivity(path, subs):

    if not path.endswith('.annotation'):
        path += '.annotation'

#    print('writing {}'.format(path))

    count = 0

    with open(path + '~', 'w', encoding='latin-1') as fp:        
        for sub in subs:      
            if not sub:
                continue
            count += 1
            start = convert_timestamp_to_s(sub.format_start())
            end = convert_timestamp_to_s(sub.format_end())  
            cap = html.unescape(sub.get_text().replace('\n', ' ').replace(';', ','))
            if not re.match('\s*\*.*\*\s*', cap) \
                and not re.match('\s*\[.*\]\s*', cap):                
                fp.write('{};{};0;1.0\n'.format(start, end)) 

    with open(path, 'w', encoding='latin-1') as fp:
        fp.write('<?xml version="1.0" ?>\n<annotation ssi-v="3">\n\t<info ftype="ASCII" size="{}" />\n\t<meta role="subtitles" annotator="system" />\n\t<scheme name="voiceactivity" type="DISCRETE" color="#FFDDD9C3">\n\t\t<item name="VOICE" id="0" color="#FF494429" />\n\t</scheme>\n</annotation>\n'.format(count)) 
開發者ID:hcmlab,項目名稱:vadnet,代碼行數:25,代碼來源:annotation.py

示例2: handle_data

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def handle_data(self, raw):
        if raw and not self.ishidden:
            if self.text[-1] == "":
                tmp = raw.lstrip()
            else:
                tmp = raw
            if self.ispref:
                line = unescape(tmp)
            else:
                line = unescape(re.sub(r"\s+", " ", tmp))
            self.text[-1] += line
            if self.ishead:
                self.idhead.add(len(self.text)-1)
            elif self.isbull:
                self.idbull.add(len(self.text)-1)
            elif self.isinde:
                self.idinde.add(len(self.text)-1)
            elif self.ispref:
                self.idpref.add(len(self.text)-1) 
開發者ID:wustho,項目名稱:epr,代碼行數:21,代碼來源:epr.py

示例3: backtracking_id

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def backtracking_id(site):
    cookies = cookies_raw2jar(site['cookies'])
    for _tid in range(site['start_torrent'], site['end_torrent'] + 2):
        t0 = time.time()

        _link = site['torrent_url'].format(_tid)
        torrent_page = requests.get(_link, cookies=cookies, headers=headers)
        title_search = re.search(site['search_ptn'], torrent_page.text)

        if title_search:
            _title = pymysql.escape_string(unescape(title_search.group("title")))
            pubDate = re.search("發布於(.+?)<", torrent_page.text).group(1)
            _timestamp = time.mktime(time.strptime(pubDate, "%Y-%m-%d %H:%M:%S"))

            wrap_insert(site=site['name'], sid=_tid, title=_title, link=_link, pubdate=_timestamp, t=t0)
        else:
            print("ID: {}, Cost: {:.5f} s, No torrent.".format(_tid, time.time() - t0))

        time.sleep(2) 
開發者ID:Rhilip,項目名稱:PT-help,代碼行數:21,代碼來源:backtracking.py

示例4: write_transcription

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def write_transcription(path, subs):
        
    if not path.endswith('.annotation'):
        path += '.annotation'

#    print('writing {}'.format(path))

    count = 0
    
    with open(path + '~', 'w', encoding='latin-1') as fp:        
        for sub in subs:    
            if not sub:
                continue
            count += 1
            start = convert_timestamp_to_s(sub.format_start())
            end = convert_timestamp_to_s(sub.format_end())  
            cap = html.unescape(sub.get_text().replace('\n', ' ').replace(';', ','))
            fp.write('{};{};{};1.0\n'.format(start, end, cap)) 

    with open(path, 'w', encoding='latin-1') as fp:
        fp.write('<?xml version="1.0" ?>\n<annotation ssi-v="3">\n\t<info ftype="ASCII" size="{}" />\n\t<meta role="youtube" annotator="system" />\n\t<scheme name="transcription" type="FREE"/>\n</annotation>\n'.format(count)) 
開發者ID:hcmlab,項目名稱:vadnet,代碼行數:23,代碼來源:annotation.py

示例5: get_labels

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def get_labels(key, fa_subs, kb_subs):
    # split into labels for each part of key
    labels = key.split('\n')
    for i, label in enumerate(labels):
        tree = lxml.html.fragment_fromstring(label, create_parent=True)
        # set key.pic to true and make label url of image
        if tree.xpath('//img[1]/@src'):
            return (tree.xpath('//img[1]/@src'), True)

        # replace icons with unicode characters
        for fa_icon in tree.find_class('fa'):
            fa_class = re.search(r'fa-\S+', fa_icon.get('class'))
            if fa_class and fa_class.group(0) in fa_subs:
                fa_icon.text = chr(int(fa_subs[fa_class.group(0)], 16))
        for kb_icon in tree.find_class('kb'):
            kb_class = re.search(r'kb-\S+', kb_icon.get('class'))
            if kb_class and kb_class.group(0) in kb_subs:
                kb_icon.text = chr(int(kb_subs[kb_class.group(0)], 16))

        # replace breaks with newlines and remove html entities
        for br in tree.xpath('//br'): br.text = '\n'
        labels[i] = html.unescape(tree.text_content())
    return (labels, False) 
開發者ID:CQCumbers,項目名稱:kle_render,代碼行數:25,代碼來源:keyboard.py

示例6: test_views_lti_video_post_error

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def test_views_lti_video_post_error(self, mock_verify, mock_logger):
        """Validate the response returned in case of an LTI exception."""
        role = random.choice(["instructor", "student"])
        data = {"resource_link_id": "123", "roles": role, "context_id": "abc"}
        response = self.client.post("/lti/videos/{!s}".format(uuid.uuid4()), data)
        self.assertEqual(response.status_code, 200)
        self.assertContains(response, "<html>")
        content = response.content.decode("utf-8")

        mock_logger.assert_called_once_with("lti error")

        match = re.search(
            '<div id="marsha-frontend-data" data-context="(.*)">', content
        )

        context = json.loads(unescape(match.group(1)))
        self.assertEqual(context.get("state"), "error")
        self.assertIsNone(context.get("resource"))
        self.assertEqual(context.get("modelName"), "videos") 
開發者ID:openfun,項目名稱:marsha,代碼行數:21,代碼來源:test_views_lti_video.py

示例7: test_views_lti_document_post_error

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def test_views_lti_document_post_error(self, mock_verify, mock_logger):
        """Validate the response returned in case of an LTI exception."""
        role = random.choice(["instructor", "student"])
        data = {"resource_link_id": "123", "roles": role, "context_id": "abc"}
        response = self.client.post("/lti/documents/{!s}".format(uuid.uuid4()), data)
        self.assertEqual(response.status_code, 200)
        self.assertContains(response, "<html>")
        content = response.content.decode("utf-8")

        mock_logger.assert_called_once_with("lti error")

        match = re.search(
            '<div id="marsha-frontend-data" data-context="(.*)">', content
        )

        context = json.loads(html.unescape(match.group(1)))
        self.assertEqual(context.get("state"), "error")
        self.assertIsNone(context.get("resource")) 
開發者ID:openfun,項目名稱:marsha,代碼行數:20,代碼來源:test_views_lti_document.py

示例8: extract_toot

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def extract_toot(toot):
	toot = html.unescape(toot) # convert HTML escape codes to text
	soup = BeautifulSoup(toot, "html.parser")
	for lb in soup.select("br"): # replace <br> with linebreak
		lb.replace_with("\n")

	for p in soup.select("p"): # ditto for <p>
		p.replace_with("\n")

	for ht in soup.select("a.hashtag"): # convert hashtags from links to text
		ht.unwrap()

	for link in soup.select("a"): #ocnvert <a href='https://example.com>example.com</a> to just https://example.com
		if 'href' in link:
			# apparently not all a tags have a href, which is understandable if you're doing normal web stuff, but on a social media platform??
			link.replace_with(link["href"])

	text = soup.get_text()
	text = re.sub(r"https://([^/]+)/(@[^\s]+)", r"\2@\1", text) # put mastodon-style mentions back in
	text = re.sub(r"https://([^/]+)/users/([^\s/]+)", r"@\2@\1", text) # put pleroma-style mentions back in
	text = text.rstrip("\n") # remove trailing newline(s)
	return text 
開發者ID:Lynnesbian,項目名稱:mstdn-ebooks,代碼行數:24,代碼來源:functions.py

示例9: unescape

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def unescape(s):
        html_parser = HTMLParser.HTMLParser()
        return html_parser.unescape(s)

# Return addrlist sequence at random, it can help create_connection function 
開發者ID:ForgQi,項目名稱:bilibiliupload,代碼行數:7,代碼來源:compact.py

示例10: _get_links

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def _get_links(self, name: str) -> List[Dict[str, str]]:
        cache = JSONCache(
            'warehouse-simple', urlparse(self.url).hostname, 'links', name,
            ttl=config['cache']['ttl'],
        )
        links = cache.load()
        if links is not None:
            yield from links
            return

        dep_url = posixpath.join(self.url, quote(name)) + '/'
        with requests_session() as session:
            logger.debug('getting dep info from simple repo', extra=dict(url=dep_url))
            response = session.get(dep_url, auth=self.auth)
        if response.status_code == 404:
            raise PackageNotFoundError(package=name, url=dep_url)
        response.raise_for_status()
        document = html5lib.parse(response.text, namespaceHTMLElements=False)

        links = []
        for tag in document.findall('.//a'):
            link = tag.get('href')
            if not link:
                continue
            parsed = urlparse(link)
            if not parsed.path.endswith(ARCHIVE_EXTENSIONS):
                continue

            python = tag.get('data-requires-python')
            fragment = parse_qs(parsed.fragment)
            link = dict(
                url=urljoin(dep_url, link),
                name=parsed.path.strip('/').split('/')[-1],
                python=html.unescape(python) if python else '*',
                digest=fragment['sha256'][0] if 'sha256' in fragment else None,
            )
            links.append(link)
            yield link

        cache.dump(links)
        return links 
開發者ID:dephell,項目名稱:dephell,代碼行數:43,代碼來源:_simple.py

示例11: escape

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def escape(s):
    return html.unescape(s).replace(os.path.sep, '、').replace(':', '_').replace(' ', '_').replace('\t', '').replace('?','.').replace('/','_').replace('\'','_').replace('<','').replace('>','').replace('#','').replace(';','').replace('*','_').replace("\"",'_').replace("\'",'_').replace('|','') 
開發者ID:Trinkle23897,項目名稱:learn2018-autodown,代碼行數:4,代碼來源:learn.py

示例12: sanitize

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def sanitize(s: str) -> str:
    """Try and corral the given string-ish thing into a unicode string. Expects input from files in arbitrary encodings and with bits of HTML in them. Useful for Lim-Dûl and similar."""
    try:
        s = s.encode('latin-1').decode('utf-8')
    except UnicodeDecodeError:
        pass
    return html.unescape(s) 
開發者ID:PennyDreadfulMTG,項目名稱:Penny-Dreadful-Tools,代碼行數:9,代碼來源:text.py

示例13: parse_cardhoarder_prices

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def parse_cardhoarder_prices(s: str) -> PriceListType:
    details = []
    for line in s.splitlines()[2:]: # Skipping date and header line.

        if line.count('\t') != 7:
            raise InvalidDataException('Bad line (cardhoarder): {line}'.format(line=line))
        _mtgo_id, mtgo_set, _mtgjson_set, set_number, name, p, quantity, _mtgjson_uuid = line.split('\t')  # pylint: disable=unused-variable
        name = html.unescape(name.strip())
        if int(quantity) > 0 and not mtgo_set.startswith('CH-') and mtgo_set != 'VAN' and mtgo_set != 'EVENT' and not re.search(r'(Booster|Commander Deck|Commander:|Theme Deck|Draft Pack|Duel Decks|Reward Pack|Intro Pack|Tournament Pack|Premium Deck Series:|From the Vault)', name):
            details.append((name, p, mtgo_set))
    return [(name_lookup(name), html.unescape(p.strip()), mtgo_set) for name, p, mtgo_set in details if name_lookup(name) is not None] 
開發者ID:PennyDreadfulMTG,項目名稱:Penny-Dreadful-Tools,代碼行數:13,代碼來源:parser.py

示例14: to_xml

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def to_xml(cls, doc):
    return html.unescape(tostring(doc).decode("utf8")) 
開發者ID:joeyism,項目名稱:py-edgar,代碼行數:4,代碼來源:txtml.py

示例15: print_rt

# 需要導入模塊: import html [as 別名]
# 或者: from html import unescape [as 別名]
def print_rt(self, tweet):
        text = html.unescape(tweet.retweeted_status.text)
        fmt = "@{user.screen_name} RT @{rt.user.screen_name}: {text}"
        return fmt.format(user=tweet.user, rt=tweet.retweeted_status,
                          text=text) 
開發者ID:odrling,項目名稱:peony-twitter,代碼行數:7,代碼來源:stream.py


注:本文中的html.unescape方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。