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


Python etree.Element方法代碼示例

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


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

示例1: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, match):
        reply_id = int(match.group(3))
        try:
            link = etree.Element("a")
            link.attrib["href"] = url_for_post(reply_id)
            link.attrib["class"] = "post-reply"
            link.attrib["data-post-id"] = str(reply_id)
            link.attrib["data-toggle"]  = "tooltip"
            link.attrib["data-placement"] = "bottom"
            link.attrib["data-html"] = "true"
            link.attrib["title"] = "<i>Loading...</i>"
            link.attrib["data-loaded"] = "false"
            link.text = "&gt;&gt;%s" % reply_id
            return link
        except NoResultFound:
            dead_reply = etree.Element("span")
            dead_reply.text = "&gt;&gt;%s" % reply_id
            dead_reply.attrib["class"] = "text-danger"
            return dead_reply 
開發者ID:DangerOnTheRanger,項目名稱:maniwani,代碼行數:21,代碼來源:PostReplyPattern.py

示例2: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, m):
            # Extract information from markdown tag
            text = m.group(2)

            ids = [
                id
                for id in m.group(3).split(',')
                if id.startswith('#')
            ]
            id = ids[0] if ids else None

            class_names = [
                class_name[1:] if class_name.startswith('.') else class_name
                for class_name in m.group(3).split(' ')
                if class_name.startswith('.')
            ]

            # Generate HTML element for new span
            el = etree.Element('span')
            el.text = text
            if id:
                el.attrib['id'] = id
            if class_names:
                el.attrib['class'] = " ".join(class_names)
            return el 
開發者ID:airbnb,項目名稱:knowledge-repo,代碼行數:27,代碼來源:html.py

示例3: run

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def run(self, root):
        parent_map = {c: p for p in root.iter() for c in p}
        images = root.getiterator("img")
        for image in images:
            desc = image.attrib["alt"]
            if self.re.match(desc):
                image.set("alt", desc)
                parent = parent_map[image]
                ix = list(parent).index(image)
                div_node = etree.Element('div')
                div_node.set("class", "lightgallery")
                new_node = etree.Element('a')
                new_node.set("href", image.attrib["src"])
                new_node.append(image)
                div_node.append(new_node)
                parent.insert(ix, div_node)
                parent.remove(image) 
開發者ID:V1EngineeringInc,項目名稱:V1EngineeringInc-Docs,代碼行數:19,代碼來源:lightgallery.py

示例4: run

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def run(self, name, optstr):
        try:
            text = name
            if optstr:
                text = optstr[0]

            page = Page.objects.get(title=name)
            url = page.url
            a = etree.Element('a')
            a.set('href', url)
            a.text = text
            return a
        except ObjectDoesNotExist:
            return '[page "{}" not found]'.format(name)
        except MultipleObjectsReturned:
            return '[multiple pages "{}" found]'.format(name) 
開發者ID:torchbox,項目名稱:wagtail-markdown,代碼行數:18,代碼來源:page.py

示例5: run

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def run(self, name, optstr):
        try:
            text = name
            if len(optstr):
                text = optstr[0]

            doc = Document.objects.get(title=name)
            url = doc.url
            a = etree.Element('a')
            a.set('href', url)
            a.text = text
            return a
        except ObjectDoesNotExist:
            return '[document "{}" not found]'.format(name)
        except MultipleObjectsReturned:
            return '[multiple documents "{}" found]'.format(name) 
開發者ID:torchbox,項目名稱:wagtail-markdown,代碼行數:18,代碼來源:document.py

示例6: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, m):
        abbr = etree.Element('abbr')
        abbr.text = m.group('abbr')
        abbr.set('title', self.title)
        return abbr 
開發者ID:ryfeus,項目名稱:lambda-packs,代碼行數:7,代碼來源:abbr.py

示例7: findFootnotesPlaceholder

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def findFootnotesPlaceholder(self, root):
        """ Return ElementTree Element that contains Footnote placeholder. """
        def finder(element):
            for child in element:
                if child.text:
                    if child.text.find(self.getConfig("PLACE_MARKER")) > -1:
                        return child, element, True
                if child.tail:
                    if child.tail.find(self.getConfig("PLACE_MARKER")) > -1:
                        return child, element, False
                finder(child)
            return None
                
        res = finder(root)
        return res 
開發者ID:ryfeus,項目名稱:lambda-packs,代碼行數:17,代碼來源:footnotes.py

示例8: makeFootnotesDiv

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def makeFootnotesDiv(self, root):
        """ Return div of footnotes as et Element. """

        if not list(self.footnotes.keys()):
            return None

        div = etree.Element("div")
        div.set('class', 'footnote')
        hr = etree.SubElement(div, "hr")
        ol = etree.SubElement(div, "ol")

        for id in list(self.footnotes.keys()):
            li = etree.SubElement(ol, "li")
            li.set("id", self.makeFootnoteId(id))
            self.parser.parseChunk(li, self.footnotes[id])
            backlink = etree.Element("a")
            backlink.set("href", "#" + self.makeFootnoteRefId(id))
            backlink.set("rev", "footnote")
            backlink.set("title", "Jump back to footnote %d in the text" % \
                            (self.footnotes.index(id)+1))
            backlink.text = FN_BACKLINK_TEXT

            if li.getchildren():
                node = li[-1]
                if node.tag == "p":
                    node.text = node.text + NBSP_PLACEHOLDER
                    node.append(backlink)
                else:
                    p = etree.SubElement(li, "p")
                    p.append(backlink)
        return div 
開發者ID:ryfeus,項目名稱:lambda-packs,代碼行數:33,代碼來源:footnotes.py

示例9: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, m):
        id = m.group(2)
        if id in list(self.footnotes.footnotes.keys()):
            sup = etree.Element("sup")
            a = etree.SubElement(sup, "a")
            sup.set('id', self.footnotes.makeFootnoteRefId(id))
            a.set('href', '#' + self.footnotes.makeFootnoteId(id))
            a.set('rel', 'footnote')
            a.text = str(self.footnotes.footnotes.index(id) + 1)
            return sup
        else:
            return None 
開發者ID:ryfeus,項目名稱:lambda-packs,代碼行數:14,代碼來源:footnotes.py

示例10: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, m):
        supr = m.group(3)
        
        text = supr
        
        el = etree.Element("sup")
        el.text = AtomicString(text)
        return el 
開發者ID:jamiemcg,項目名稱:Remarkable,代碼行數:10,代碼來源:superscript.py

示例11: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, m):
        subsc = m.group(3)
        
        text = subsc
        
        el = etree.Element("sub")
        el.text = AtomicString(text)
        return el 
開發者ID:jamiemcg,項目名稱:Remarkable,代碼行數:10,代碼來源:subscript.py

示例12: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, match):
        return etree.Element("br") 
開發者ID:DangerOnTheRanger,項目名稱:maniwani,代碼行數:4,代碼來源:SpacingExtension.py

示例13: handleMatch

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def handleMatch(self, match):
        spoiler = etree.Element("span")
        spoiler.text = match.group(2)
        spoiler.attrib["class"] = "spoiler"
        return spoiler 
開發者ID:DangerOnTheRanger,項目名稱:maniwani,代碼行數:7,代碼來源:Spoiler.py

示例14: insert_permalinks

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def insert_permalinks(el, permalink_text=None, permalink_class=None, permalink_title=None):
    for child in el:
        if child.tag in {'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'h7', 'h8'}:
            permalink = etree.Element('a')

            # try to get any existing ID from the heading tag
            id = child.get('id', None)
            # if there is none, slugify the text of the heading tag
            if id is None:
                heading_text = strip_el_text(child, max_depth=3)
                id = slugify(heading_text.replace('\'', '').replace('"', ''))
                # apply the ID to the heading
                child.set('id', id)

            permalink.set('href', '#%s' % id)

            if permalink_class is not None:
                permalink.set('class', permalink_class)
            if permalink_title is not None:
                permalink.set('title', permalink_title)

            if permalink_text is not None:
                permalink.text = permalink_text

            child.append(permalink)

        # recursively insert permalinks
        insert_permalinks(
            child,
            permalink_text=permalink_text,
            permalink_class=permalink_class,
            permalink_title=permalink_title
        ) 
開發者ID:thanethomson,項目名稱:statik,代碼行數:35,代碼來源:markdown_exts.py

示例15: run

# 需要導入模塊: from markdown.util import etree [as 別名]
# 或者: from markdown.util.etree import Element [as 別名]
def run (self, root):

        rss = etree.Element("rss")
        rss.set("version", "2.0")

        channel = etree.SubElement(rss, "channel")

        for tag, text in (("title", self.ext.getConfig("TITLE")),
                          ("link", self.ext.getConfig("URL")),
                          ("description", None)):
            
            element = etree.SubElement(channel, tag)
            element.text = text

        for child in root:

            if child.tag in ["h1", "h2", "h3", "h4", "h5"]:
      
                heading = child.text.strip()
                item = etree.SubElement(channel, "item")
                link = etree.SubElement(item, "link")
                link.text = self.ext.getConfig("URL")
                title = etree.SubElement(item, "title")
                title.text = heading

                guid = ''.join([x for x in heading if x.isalnum()])
                guidElem = etree.SubElement(item, "guid")
                guidElem.text = guid
                guidElem.set("isPermaLink", "false")

            elif child.tag in ["p"]:
                try:
                    description = etree.SubElement(item, "description")
                except UnboundLocalError:
                    # Item not defined - moving on
                    pass
                else:
                    if len(child):
                        content = "\n".join([etree.tostring(node)
                                             for node in child])
                    else:
                        content = child.text
                    pholder = self.markdown.htmlStash.store(
                                                "<![CDATA[ %s]]>" % content)
                    description.text = pholder
    
        return rss 
開發者ID:ryfeus,項目名稱:lambda-packs,代碼行數:49,代碼來源:rss.py


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