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


Python util.unicode_type方法代碼示例

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


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

示例1: url_unescape

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def url_unescape(value, encoding='utf-8', plus=True):
        """解碼來自於URL 的給定值.

        該參數可以是一個字節或unicode 字符串.

        如果encoding 是None , 該結果將會是一個字節串. 否則, 該結果會是
        指定編碼的unicode 字符串.

        如果 ``plus`` 是true (默認值), 加號將被解釋為空格(文字加號必須被
        表示為"%2B"). 這是適用於查詢字符串和form-encoded 的值, 但不是URL
        的路徑組件. 注意該默認設置和Python 的urllib 模塊是相反的.

        .. versionadded:: 3.1
           該 ``plus`` 參數
        """
        unquote = (urllib_parse.unquote_plus if plus else urllib_parse.unquote)
        if encoding is None:
            return unquote(utf8(value))
        else:
            return unicode_type(unquote(utf8(value)), encoding) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:22,代碼來源:escape.py

示例2: get

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def get(self, *path_args):
        # Type checks: web.py interfaces convert argument values to
        # unicode strings (by default, but see also decode_argument).
        # In httpserver.py (i.e. self.request.arguments), they're left
        # as bytes.  Keys are always native strings.
        for key in self.request.arguments:
            if type(key) != str:
                raise Exception("incorrect type for key: %r" % type(key))
            for value in self.request.arguments[key]:
                if type(value) != bytes:
                    raise Exception("incorrect type for value: %r" %
                                    type(value))
            for value in self.get_arguments(key):
                if type(value) != unicode_type:
                    raise Exception("incorrect type for value: %r" %
                                    type(value))
        for arg in path_args:
            if type(arg) != unicode_type:
                raise Exception("incorrect type for path arg: %r" % type(arg))
        self.write(dict(path=self.request.path,
                        path_args=path_args,
                        args=recursive_unicode(self.request.arguments))) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:24,代碼來源:web_test.py

示例3: prepare

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def prepare(self):
        self.errors = {}

        self.check_type('status', self.get_status(), int)

        # get_argument is an exception from the general rule of using
        # type str for non-body data mainly for historical reasons.
        self.check_type('argument', self.get_argument('foo'), unicode_type)
        self.check_type('cookie_key', list(self.cookies.keys())[0], str)
        self.check_type('cookie_value', list(self.cookies.values())[0].value, str)

        # Secure cookies return bytes because they can contain arbitrary
        # data, but regular cookies are native strings.
        if list(self.cookies.keys()) != ['asdf']:
            raise Exception("unexpected values for cookie keys: %r" %
                            self.cookies.keys())
        self.check_type('get_secure_cookie', self.get_secure_cookie('asdf'), bytes)
        self.check_type('get_cookie', self.get_cookie('asdf'), str)

        self.check_type('xsrf_token', self.xsrf_token, bytes)
        self.check_type('xsrf_form_html', self.xsrf_form_html(), str)

        self.check_type('reverse_url', self.reverse_url('typecheck', 'foo'), str)

        self.check_type('request_summary', self._request_summary(), str) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:27,代碼來源:web_test.py

示例4: url_unescape

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def url_unescape(value, encoding='utf-8', plus=True):
        """Decodes the given value from a URL.

        The argument may be either a byte or unicode string.

        If encoding is None, the result will be a byte string.  Otherwise,
        the result is a unicode string in the specified encoding.

        If ``plus`` is true (the default), plus signs will be interpreted
        as spaces (literal plus signs must be represented as "%2B").  This
        is appropriate for query strings and form-encoded values but not
        for the path component of a URL.  Note that this default is the
        reverse of Python's urllib module.

        .. versionadded:: 3.1
           The ``plus`` argument
        """
        unquote = (urllib_parse.unquote_plus if plus else urllib_parse.unquote)
        if encoding is None:
            return unquote(utf8(value))
        else:
            return unicode_type(unquote(utf8(value)), encoding) 
開發者ID:viewfinderco,項目名稱:viewfinder,代碼行數:24,代碼來源:escape.py

示例5: _convert_header_value

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def _convert_header_value(self, value):
        if isinstance(value, bytes_type):
            pass
        elif isinstance(value, unicode_type):
            value = value.encode('utf-8')
        elif isinstance(value, numbers.Integral):
            # return immediately since we know the converted value will be safe
            return str(value)
        elif isinstance(value, datetime.datetime):
            return httputil.format_timestamp(value)
        else:
            raise TypeError("Unsupported header value %r" % value)
        # If \n is allowed into the header, it is possible to inject
        # additional headers or split the request. Also cap length to
        # prevent obviously erroneous values.
        if (len(value) > 4000 or
                RequestHandler._INVALID_HEADER_CHAR_RE.search(value)):
            raise ValueError("Unsafe header value %r", value)
        return value 
開發者ID:viewfinderco,項目名稱:viewfinder,代碼行數:21,代碼來源:web.py

示例6: get_arguments

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def get_arguments(self, name, strip=True):
        """Returns a list of the arguments with the given name.

        If the argument is not present, returns an empty list.

        The returned values are always unicode.
        """

        values = []
        for v in self.request.arguments.get(name, []):
            v = self.decode_argument(v, name=name)
            if isinstance(v, unicode_type):
                # Get rid of any weird control chars (unless decoding gave
                # us bytes, in which case leave it alone)
                v = RequestHandler._remove_control_chars_regex.sub(" ", v)
            if strip:
                v = v.strip()
            values.append(v)
        return values 
開發者ID:viewfinderco,項目名稱:viewfinder,代碼行數:21,代碼來源:web.py

示例7: get

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def get(self, *path_args):
        # Type checks: web.py interfaces convert argument values to
        # unicode strings (by default, but see also decode_argument).
        # In httpserver.py (i.e. self.request.arguments), they're left
        # as bytes.  Keys are always native strings.
        for key in self.request.arguments:
            if type(key) != str:
                raise Exception("incorrect type for key: %r" % type(key))
            for value in self.request.arguments[key]:
                if type(value) != bytes_type:
                    raise Exception("incorrect type for value: %r" %
                                    type(value))
            for value in self.get_arguments(key):
                if type(value) != unicode_type:
                    raise Exception("incorrect type for value: %r" %
                                    type(value))
        for arg in path_args:
            if type(arg) != unicode_type:
                raise Exception("incorrect type for path arg: %r" % type(arg))
        self.write(dict(path=self.request.path,
                        path_args=path_args,
                        args=recursive_unicode(self.request.arguments))) 
開發者ID:viewfinderco,項目名稱:viewfinder,代碼行數:24,代碼來源:web_test.py

示例8: prepare

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def prepare(self):
        self.errors = {}

        self.check_type('status', self.get_status(), int)

        # get_argument is an exception from the general rule of using
        # type str for non-body data mainly for historical reasons.
        self.check_type('argument', self.get_argument('foo'), unicode_type)
        self.check_type('cookie_key', list(self.cookies.keys())[0], str)
        self.check_type('cookie_value', list(self.cookies.values())[0].value, str)

        # Secure cookies return bytes because they can contain arbitrary
        # data, but regular cookies are native strings.
        if list(self.cookies.keys()) != ['asdf']:
            raise Exception("unexpected values for cookie keys: %r" %
                            self.cookies.keys())
        self.check_type('get_secure_cookie', self.get_secure_cookie('asdf'), bytes_type)
        self.check_type('get_cookie', self.get_cookie('asdf'), str)

        self.check_type('xsrf_token', self.xsrf_token, bytes_type)
        self.check_type('xsrf_form_html', self.xsrf_form_html(), str)

        self.check_type('reverse_url', self.reverse_url('typecheck', 'foo'), str)

        self.check_type('request_summary', self._request_summary(), str) 
開發者ID:viewfinderco,項目名稱:viewfinder,代碼行數:27,代碼來源:web_test.py

示例9: utf8

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def utf8(value):
    """將字符串參數轉換為字節字符串.

    如果該參數已經是一個字節字符串或None, 則原樣返回.
    否則它必須是一個unicode 字符串並且被編碼成utf8.
    """
    if isinstance(value, _UTF8_TYPES):
        return value
    if not isinstance(value, unicode_type):
        raise TypeError(
            "Expected bytes, unicode, or None; got %r" % type(value)
        )
    return value.encode("utf-8") 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:15,代碼來源:escape.py

示例10: _oauth_escape

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def _oauth_escape(val):
    if isinstance(val, unicode_type):
        val = val.encode("utf-8")
    return urllib_parse.quote(val, safe="~") 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:6,代碼來源:auth.py

示例11: __init__

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def __init__(self, color=True, fmt=DEFAULT_FORMAT,
                 datefmt=DEFAULT_DATE_FORMAT, colors=DEFAULT_COLORS):
        r"""
        :arg bool color: Enables color support.
        :arg string fmt: Log message format.
          It will be applied to the attributes dict of log records. The
          text between ``%(color)s`` and ``%(end_color)s`` will be colored
          depending on the level if color support is on.
        :arg dict colors: color mappings from logging level to terminal color
          code
        :arg string datefmt: Datetime format.
          Used for formatting ``(asctime)`` placeholder in ``prefix_fmt``.

        .. versionchanged:: 3.2

           Added ``fmt`` and ``datefmt`` arguments.
        """
        logging.Formatter.__init__(self, datefmt=datefmt)
        self._fmt = fmt

        self._colors = {}
        if color and _stderr_supports_color():
            # The curses module has some str/bytes confusion in
            # python3.  Until version 3.2.3, most methods return
            # bytes, but only accept strings.  In addition, we want to
            # output these strings with the logging module, which
            # works with unicode strings.  The explicit calls to
            # unicode() below are harmless in python2 but will do the
            # right conversion in python 3.
            fg_color = (curses.tigetstr("setaf") or
                        curses.tigetstr("setf") or "")
            if (3, 0) < sys.version_info < (3, 2, 3):
                fg_color = unicode_type(fg_color, "ascii")

            for levelno, code in colors.items():
                self._colors[levelno] = unicode_type(curses.tparm(fg_color, code), "ascii")
            self._normal = unicode_type(curses.tigetstr("sgr0"), "ascii")
        else:
            self._normal = '' 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:41,代碼來源:log.py

示例12: generate

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def generate(self, **kwargs):
        """用給定參數生成此模板."""
        namespace = {
            "escape": escape.xhtml_escape,
            "xhtml_escape": escape.xhtml_escape,
            "url_escape": escape.url_escape,
            "json_encode": escape.json_encode,
            "squeeze": escape.squeeze,
            "linkify": escape.linkify,
            "datetime": datetime,
            "_tt_utf8": escape.utf8,  # for internal use
            "_tt_string_types": (unicode_type, bytes),
            # __name__ and __loader__ allow the traceback mechanism to find
            # the generated source code.
            "__name__": self.name.replace('.', '_'),
            "__loader__": ObjectDict(get_source=lambda name: self.code),
        }
        namespace.update(self.namespace)
        namespace.update(kwargs)
        exec_in(self.compiled, namespace)
        execute = namespace["_tt_execute"]
        # Clear the traceback module's cache of source data now that
        # we've generated a new template (mainly for this module's
        # unittests, where different tests reuse the same name).
        linecache.clearcache()
        return execute() 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:28,代碼來源:template.py

示例13: post

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def post(self, path_component):
        self.check_type('path_component', path_component, unicode_type)
        self.write(self.errors) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:5,代碼來源:web_test.py

示例14: test_escape_return_types

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def test_escape_return_types(self):
        # On python2 the escape methods should generally return the same
        # type as their argument
        self.assertEqual(type(xhtml_escape("foo")), str)
        self.assertEqual(type(xhtml_escape(u("foo"))), unicode_type) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:7,代碼來源:escape_test.py

示例15: test_unicode_literal_expression

# 需要導入模塊: from tornado import util [as 別名]
# 或者: from tornado.util import unicode_type [as 別名]
def test_unicode_literal_expression(self):
        # Unicode literals should be usable in templates.  Note that this
        # test simulates unicode characters appearing directly in the
        # template file (with utf8 encoding), i.e. \u escapes would not
        # be used in the template file itself.
        if str is unicode_type:
            # python 3 needs a different version of this test since
            # 2to3 doesn't run on template internals
            template = Template(utf8(u('{{ "\u00e9" }}')))
        else:
            template = Template(utf8(u('{{ u"\u00e9" }}')))
        self.assertEqual(template.generate(), utf8(u("\u00e9"))) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:14,代碼來源:template_test.py


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