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


Python more_itertools.always_iterable方法代碼示例

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


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

示例1: __init__

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def __init__(self, urls, status=None, encoding=None):
        self.urls = abs_urls = [
            # Note that urljoin will "do the right thing" whether url is:
            #  1. a complete URL with host (e.g. "http://www.example.com/test")
            #  2. a URL relative to root (e.g. "/dummy")
            #  3. a URL relative to the current path
            # Note that any query string in cherrypy.request is discarded.
            urllib.parse.urljoin(
                cherrypy.url(),
                tonative(url, encoding or self.encoding),
            )
            for url in always_iterable(urls)
        ]

        status = (
            int(status)
            if status is not None
            else self.default_status
        )
        if not 300 <= status <= 399:
            raise ValueError('status must be between 300 and 399.')

        CherryPyException.__init__(self, abs_urls, status) 
開發者ID:cherrypy,項目名稱:cherrypy,代碼行數:25,代碼來源:_cperror.py

示例2: send_response

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def send_response(req, status, headers, body, stream=False):
    # Set response status
    req.status = int(status[:3])

    # Set response headers
    req.content_type = 'text/plain'
    for header, value in headers:
        if header.lower() == 'content-type':
            req.content_type = value
            continue
        req.headers_out.add(header, value)

    if stream:
        # Flush now so the status and headers are sent immediately.
        req.flush()

    # Set response body
    for seg in always_iterable(body):
        req.write(seg)


# --------------- Startup tools for CherryPy + mod_python --------------- # 
開發者ID:cherrypy,項目名稱:cherrypy,代碼行數:24,代碼來源:_cpmodpy.py

示例3: test_base_type

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def test_base_type(self):
        dict_obj = {'a': 1, 'b': 2}
        str_obj = '123'

        # Default: dicts are iterable like they normally are
        default_actual = list(mi.always_iterable(dict_obj))
        default_expected = list(dict_obj)
        self.assertEqual(default_actual, default_expected)

        # Unitary types set: dicts are not iterable
        custom_actual = list(mi.always_iterable(dict_obj, base_type=dict))
        custom_expected = [dict_obj]
        self.assertEqual(custom_actual, custom_expected)

        # With unitary types set, strings are iterable
        str_actual = list(mi.always_iterable(str_obj, base_type=None))
        str_expected = list(str_obj)
        self.assertEqual(str_actual, str_expected) 
開發者ID:sofia-netsurv,項目名稱:python-netsurv,代碼行數:20,代碼來源:test_more.py

示例4: wait

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def wait(self, state, interval=0.1, channel=None):
        """Poll for the given state(s) at intervals; publish to channel."""
        states = set(always_iterable(state))

        while self.state not in states:
            time.sleep(interval)
            self.publish(channel) 
開發者ID:cherrypy,項目名稱:cherrypy,代碼行數:9,代碼來源:wspbus.py

示例5: test_single

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def test_single(self):
        self.assertEqual(list(mi.always_iterable(1)), [1]) 
開發者ID:sofia-netsurv,項目名稱:python-netsurv,代碼行數:4,代碼來源:test_more.py

示例6: test_strings

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def test_strings(self):
        for obj in ['foo', b'bar', 'baz']:
            actual = list(mi.always_iterable(obj))
            expected = [obj]
            self.assertEqual(actual, expected) 
開發者ID:sofia-netsurv,項目名稱:python-netsurv,代碼行數:7,代碼來源:test_more.py

示例7: test_iterables

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def test_iterables(self):
        self.assertEqual(list(mi.always_iterable([0, 1])), [0, 1])
        self.assertEqual(
            list(mi.always_iterable([0, 1], base_type=list)), [[0, 1]]
        )
        self.assertEqual(
            list(mi.always_iterable(iter('foo'))), ['f', 'o', 'o']
        )
        self.assertEqual(list(mi.always_iterable([])), []) 
開發者ID:sofia-netsurv,項目名稱:python-netsurv,代碼行數:11,代碼來源:test_more.py

示例8: test_none

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def test_none(self):
        self.assertEqual(list(mi.always_iterable(None)), []) 
開發者ID:sofia-netsurv,項目名稱:python-netsurv,代碼行數:4,代碼來源:test_more.py

示例9: list

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def list(self, channels=None, server=""):
        """Send a LIST command."""
        self.send_items('LIST', ','.join(always_iterable(channels)), server) 
開發者ID:jaraco,項目名稱:irc,代碼行數:5,代碼來源:client.py

示例10: names

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def names(self, channels=None):
        """Send a NAMES command."""
        self.send_items('NAMES', ','.join(always_iterable(channels))) 
開發者ID:jaraco,項目名稱:irc,代碼行數:5,代碼來源:client.py

示例11: part

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def part(self, channels, message=""):
        """Send a PART command."""
        self.send_items('PART', ','.join(always_iterable(channels)), message) 
開發者ID:jaraco,項目名稱:irc,代碼行數:5,代碼來源:client.py

示例12: whois

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def whois(self, targets):
        """Send a WHOIS command."""
        self.send_items('WHOIS', ",".join(always_iterable(targets))) 
開發者ID:jaraco,項目名稱:irc,代碼行數:5,代碼來源:client.py

示例13: from_doc

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def from_doc(cls, doc):
        """
        Load instances from the xmltodict result. Always return
        an iterable, even if the result is a singleton.
        """
        return map(cls, always_iterable(doc)) 
開發者ID:jaraco,項目名稱:wolframalpha,代碼行數:8,代碼來源:__init__.py

示例14: test_generator

# 需要導入模塊: import more_itertools [as 別名]
# 或者: from more_itertools import always_iterable [as 別名]
def test_generator(self):
        def _gen():
            yield 0
            yield 1

        self.assertEqual(list(mi.always_iterable(_gen())), [0, 1]) 
開發者ID:Tautulli,項目名稱:Tautulli,代碼行數:8,代碼來源:test_more.py


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