Psyduck - 可達鴨 之 鴨力山大2


Server : LiteSpeed
System : Linux premium217.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User : alloknri ( 880)
PHP Version : 8.1.34
Disable Function : NONE
Directory :  /opt/alt/python34/lib64/python3.4/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //opt/alt/python34/lib64/python3.4/string.py
"""A collection of string constants.

Public module variables:

whitespace -- a string containing all ASCII whitespace
ascii_lowercase -- a string containing all ASCII lowercase letters
ascii_uppercase -- a string containing all ASCII uppercase letters
ascii_letters -- a string containing all ASCII letters
digits -- a string containing all ASCII decimal digits
hexdigits -- a string containing all ASCII hexadecimal digits
octdigits -- a string containing all ASCII octal digits
punctuation -- a string containing all ASCII punctuation characters
printable -- a string containing all ASCII characters considered printable

"""

import _string

# Some strings for ctype-style character classification
whitespace = ' \t\n\r\v\f'
ascii_lowercase = 'abcdefghijklmnopqrstuvwxyz'
ascii_uppercase = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
ascii_letters = ascii_lowercase + ascii_uppercase
digits = '0123456789'
hexdigits = digits + 'abcdef' + 'ABCDEF'
octdigits = '01234567'
punctuation = """!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~"""
printable = digits + ascii_letters + punctuation + whitespace

# Functions which aren't available as string methods.

# Capitalize the words in a string, e.g. " aBc  dEf " -> "Abc Def".
def capwords(s, sep=None):
    """capwords(s [,sep]) -> string

    Split the argument into words using split, capitalize each
    word using capitalize, and join the capitalized words using
    join.  If the optional second argument sep is absent or None,
    runs of whitespace characters are replaced by a single space
    and leading and trailing whitespace are removed, otherwise
    sep is used to split and join the words.

    """
    return (sep or ' ').join(x.capitalize() for x in s.split(sep))


####################################################################
import re as _re
from collections import ChainMap

class _TemplateMetaclass(type):
    pattern = r"""
    %(delim)s(?:
      (?P<escaped>%(delim)s) |   # Escape sequence of two delimiters
      (?P<named>%(id)s)      |   # delimiter and a Python identifier
      {(?P<braced>%(id)s)}   |   # delimiter and a braced identifier
      (?P<invalid>)              # Other ill-formed delimiter exprs
    )
    """

    def __init__(cls, name, bases, dct):
        super(_TemplateMetaclass, cls).__init__(name, bases, dct)
        if 'pattern' in dct:
            pattern = cls.pattern
        else:
            pattern = _TemplateMetaclass.pattern % {
                'delim' : _re.escape(cls.delimiter),
                'id'    : cls.idpattern,
                }
        cls.pattern = _re.compile(pattern, cls.flags | _re.VERBOSE)


class Template(metaclass=_TemplateMetaclass):
    """A string class for supporting $-substitutions."""

    delimiter = '$'
    idpattern = r'[_a-z][_a-z0-9]*'
    flags = _re.IGNORECASE

    def __init__(self, template):
        self.template = template

    # Search for $$, $identifier, ${identifier}, and any bare $'s

    def _invalid(self, mo):
        i = mo.start('invalid')
        lines = self.template[:i].splitlines(keepends=True)
        if not lines:
            colno = 1
            lineno = 1
        else:
            colno = i - len(''.join(lines[:-1]))
            lineno = len(lines)
        raise ValueError('Invalid placeholder in string: line %d, col %d' %
                         (lineno, colno))

    def substitute(*args, **kws):
        if not args:
            raise TypeError("descriptor 'substitute' of 'Template' object "
                            "needs an argument")
        self, *args = args  # allow the "self" keyword be passed
        if len(args) > 1:
            raise TypeError('Too many positional arguments')
        if not args:
            mapping = kws
        elif kws:
            mapping = ChainMap(kws, args[0])
        else:
            mapping = args[0]
        # Helper function for .sub()
        def convert(mo):
            # Check the most common path first.
            named = mo.group('named') or mo.group('braced')
            if named is not None:
                val = mapping[named]
                # We use this idiom instead of str() because the latter will
                # fail if val is a Unicode containing non-ASCII characters.
                return '%s' % (val,)
            if mo.group('escaped') is not None:
                return self.delimiter
            if mo.group('invalid') is not None:
                self._invalid(mo)
            raise ValueError('Unrecognized named group in pattern',
                             self.pattern)
        return self.pattern.sub(convert, self.template)

    def safe_substitute(*args, **kws):
        if not args:
            raise TypeError("descriptor 'safe_substitute' of 'Template' object "
                            "needs an argument")
        self, *args = args  # allow the "self" keyword be passed
        if len(args) > 1:
            raise TypeError('Too many positional arguments')
        if not args:
            mapping = kws
        elif kws:
            mapping = ChainMap(kws, args[0])
        else:
            mapping = args[0]
        # Helper function for .sub()
        def convert(mo):
            named = mo.group('named') or mo.group('braced')
            if named is not None:
                try:
                    # We use this idiom instead of str() because the latter
                    # will fail if val is a Unicode containing non-ASCII
                    return '%s' % (mapping[named],)
                except KeyError:
                    return mo.group()
            if mo.group('escaped') is not None:
                return self.delimiter
            if mo.group('invalid') is not None:
                return mo.group()
            raise ValueError('Unrecognized named group in pattern',
                             self.pattern)
        return self.pattern.sub(convert, self.template)



########################################################################
# the Formatter class
# see PEP 3101 for details and purpose of this class

# The hard parts are reused from the C implementation.  They're exposed as "_"
# prefixed methods of str.

# The overall parser is implemented in _string.formatter_parser.
# The field name parser is implemented in _string.formatter_field_name_split

class Formatter:
    def format(*args, **kwargs):
        if not args:
            raise TypeError("descriptor 'format' of 'Formatter' object "
                            "needs an argument")
        self, *args = args  # allow the "self" keyword be passed
        try:
            format_string, *args = args # allow the "format_string" keyword be passed
        except ValueError:
            if 'format_string' in kwargs:
                format_string = kwargs.pop('format_string')
            else:
                raise TypeError("format() missing 1 required positional "
                                "argument: 'format_string'") from None
        return self.vformat(format_string, args, kwargs)

    def vformat(self, format_string, args, kwargs):
        used_args = set()
        result, _ = self._vformat(format_string, args, kwargs, used_args, 2)
        self.check_unused_args(used_args, args, kwargs)
        return result

    def _vformat(self, format_string, args, kwargs, used_args, recursion_depth,
                 auto_arg_index=0):
        if recursion_depth < 0:
            raise ValueError('Max string recursion exceeded')
        result = []
        for literal_text, field_name, format_spec, conversion in \
                self.parse(format_string):

            # output the literal text
            if literal_text:
                result.append(literal_text)

            # if there's a field, output it
            if field_name is not None:
                # this is some markup, find the object and do
                #  the formatting

                # handle arg indexing when empty field_names are given.
                if field_name == '':
                    if auto_arg_index is False:
                        raise ValueError('cannot switch from manual field '
                                         'specification to automatic field '
                                         'numbering')
                    field_name = str(auto_arg_index)
                    auto_arg_index += 1
                elif field_name.isdigit():
                    if auto_arg_index:
                        raise ValueError('cannot switch from manual field '
                                         'specification to automatic field '
                                         'numbering')
                    # disable auto arg incrementing, if it gets
                    # used later on, then an exception will be raised
                    auto_arg_index = False

                # given the field_name, find the object it references
                #  and the argument it came from
                obj, arg_used = self.get_field(field_name, args, kwargs)
                used_args.add(arg_used)

                # do any conversion on the resulting object
                obj = self.convert_field(obj, conversion)

                # expand the format spec, if needed
                format_spec, auto_arg_index = self._vformat(
                    format_spec, args, kwargs,
                    used_args, recursion_depth-1,
                    auto_arg_index=auto_arg_index)

                # format the object and append to the result
                result.append(self.format_field(obj, format_spec))

        return ''.join(result), auto_arg_index


    def get_value(self, key, args, kwargs):
        if isinstance(key, int):
            return args[key]
        else:
            return kwargs[key]


    def check_unused_args(self, used_args, args, kwargs):
        pass


    def format_field(self, value, format_spec):
        return format(value, format_spec)


    def convert_field(self, value, conversion):
        # do any conversion on the resulting object
        if conversion is None:
            return value
        elif conversion == 's':
            return str(value)
        elif conversion == 'r':
            return repr(value)
        elif conversion == 'a':
            return ascii(value)
        raise ValueError("Unknown conversion specifier {0!s}".format(conversion))


    # returns an iterable that contains tuples of the form:
    # (literal_text, field_name, format_spec, conversion)
    # literal_text can be zero length
    # field_name can be None, in which case there's no
    #  object to format and output
    # if field_name is not None, it is looked up, formatted
    #  with format_spec and conversion and then used
    def parse(self, format_string):
        return _string.formatter_parser(format_string)


    # given a field_name, find the object it references.
    #  field_name:   the field being looked up, e.g. "0.name"
    #                 or "lookup[3]"
    #  used_args:    a set of which args have been used
    #  args, kwargs: as passed in to vformat
    def get_field(self, field_name, args, kwargs):
        first, rest = _string.formatter_field_name_split(field_name)

        obj = self.get_value(first, args, kwargs)

        # loop through the rest of the field_name, doing
        #  getattr or getitem as needed
        for is_attr, i in rest:
            if is_attr:
                obj = getattr(obj, i)
            else:
                obj = obj[i]

        return obj, first
Name
Size
Permissions
Options
__pycache__
--
drwxr-xr-x
asyncio
--
drwxr-xr-x
collections
--
drwxr-xr-x
concurrent
--
drwxr-xr-x
config-3.4m
--
drwxr-xr-x
ctypes
--
drwxr-xr-x
curses
--
drwxr-xr-x
dbm
--
drwxr-xr-x
distutils
--
drwxr-xr-x
email
--
drwxr-xr-x
encodings
--
drwxr-xr-x
ensurepip
--
drwxr-xr-x
html
--
drwxr-xr-x
http
--
drwxr-xr-x
idlelib
--
drwxr-xr-x
importlib
--
drwxr-xr-x
json
--
drwxr-xr-x
lib-dynload
--
drwxr-xr-x
lib2to3
--
drwxr-xr-x
logging
--
drwxr-xr-x
multiprocessing
--
drwxr-xr-x
plat-linux
--
drwxr-xr-x
pydoc_data
--
drwxr-xr-x
site-packages
--
drwxr-xr-x
sqlite3
--
drwxr-xr-x
test
--
drwxr-xr-x
unittest
--
drwxr-xr-x
urllib
--
drwxr-xr-x
venv
--
drwxr-xr-x
wsgiref
--
drwxr-xr-x
xml
--
drwxr-xr-x
xmlrpc
--
drwxr-xr-x
__future__.py
4.477 KB
-rw-r--r--
__phello__.foo.py
0.063 KB
-rw-r--r--
_bootlocale.py
1.271 KB
-rw-r--r--
_collections_abc.py
19.432 KB
-rw-r--r--
_compat_pickle.py
8.123 KB
-rw-r--r--
_dummy_thread.py
4.758 KB
-rw-r--r--
_markupbase.py
14.256 KB
-rw-r--r--
_osx_support.py
18.653 KB
-rw-r--r--
_pyio.py
72.161 KB
-rw-r--r--
_sitebuiltins.py
3.042 KB
-rw-r--r--
_strptime.py
21.536 KB
-rw-r--r--
_sysconfigdata.py
28.055 KB
-rw-r--r--
_threading_local.py
7.236 KB
-rw-r--r--
_weakrefset.py
5.571 KB
-rw-r--r--
abc.py
8.422 KB
-rw-r--r--
aifc.py
30.838 KB
-rw-r--r--
antigravity.py
0.464 KB
-rw-r--r--
argparse.py
87.917 KB
-rw-r--r--
ast.py
11.752 KB
-rw-r--r--
asynchat.py
11.548 KB
-rw-r--r--
asyncore.py
20.506 KB
-rw-r--r--
base64.py
19.707 KB
-rwxr-xr-x
bdb.py
22.807 KB
-rw-r--r--
binhex.py
13.602 KB
-rw-r--r--
bisect.py
2.534 KB
-rw-r--r--
bz2.py
18.418 KB
-rw-r--r--
cProfile.py
5.199 KB
-rwxr-xr-x
calendar.py
22.403 KB
-rw-r--r--
cgi.py
35.099 KB
-rwxr-xr-x
cgitb.py
11.759 KB
-rw-r--r--
chunk.py
5.298 KB
-rw-r--r--
cmd.py
14.512 KB
-rw-r--r--
code.py
9.802 KB
-rw-r--r--
codecs.py
35.068 KB
-rw-r--r--
codeop.py
5.854 KB
-rw-r--r--
colorsys.py
3.969 KB
-rw-r--r--
compileall.py
9.393 KB
-rw-r--r--
configparser.py
48.533 KB
-rw-r--r--
contextlib.py
11.366 KB
-rw-r--r--
copy.py
8.794 KB
-rw-r--r--
copyreg.py
6.673 KB
-rw-r--r--
crypt.py
1.835 KB
-rw-r--r--
csv.py
15.806 KB
-rw-r--r--
datetime.py
74.027 KB
-rw-r--r--
decimal.py
223.328 KB
-rw-r--r--
difflib.py
79.77 KB
-rw-r--r--
dis.py
16.758 KB
-rw-r--r--
doctest.py
102.043 KB
-rw-r--r--
dummy_threading.py
2.749 KB
-rw-r--r--
enum.py
21.033 KB
-rw-r--r--
filecmp.py
9.6 KB
-rw-r--r--
fileinput.py
14.517 KB
-rw-r--r--
fnmatch.py
3.089 KB
-rw-r--r--
formatter.py
14.817 KB
-rw-r--r--
fractions.py
22.659 KB
-rw-r--r--
ftplib.py
37.629 KB
-rw-r--r--
functools.py
27.843 KB
-rw-r--r--
genericpath.py
3.791 KB
-rw-r--r--
getopt.py
7.313 KB
-rw-r--r--
getpass.py
5.927 KB
-rw-r--r--
gettext.py
20.28 KB
-rw-r--r--
glob.py
3.38 KB
-rw-r--r--
gzip.py
23.744 KB
-rw-r--r--
hashlib.py
9.619 KB
-rw-r--r--
heapq.py
17.575 KB
-rw-r--r--
hmac.py
4.944 KB
-rw-r--r--
imaplib.py
49.089 KB
-rw-r--r--
imghdr.py
3.445 KB
-rw-r--r--
imp.py
9.75 KB
-rw-r--r--
inspect.py
102.188 KB
-rw-r--r--
io.py
3.316 KB
-rw-r--r--
ipaddress.py
69.92 KB
-rw-r--r--
keyword.py
2.17 KB
-rwxr-xr-x
linecache.py
3.86 KB
-rw-r--r--
locale.py
72.783 KB
-rw-r--r--
lzma.py
18.917 KB
-rw-r--r--
macpath.py
5.487 KB
-rw-r--r--
macurl2path.py
2.668 KB
-rw-r--r--
mailbox.py
76.545 KB
-rw-r--r--
mailcap.py
7.263 KB
-rw-r--r--
mimetypes.py
20.294 KB
-rw-r--r--
modulefinder.py
22.872 KB
-rw-r--r--
netrc.py
5.613 KB
-rw-r--r--
nntplib.py
42.072 KB
-rw-r--r--
ntpath.py
19.997 KB
-rw-r--r--
nturl2path.py
2.387 KB
-rw-r--r--
numbers.py
10.003 KB
-rw-r--r--
opcode.py
5.314 KB
-rw-r--r--
operator.py
8.979 KB
-rw-r--r--
optparse.py
58.932 KB
-rw-r--r--
os.py
33.088 KB
-rw-r--r--
pathlib.py
41.472 KB
-rw-r--r--
pdb.py
59.563 KB
-rwxr-xr-x
pickle.py
54.677 KB
-rw-r--r--
pickletools.py
89.611 KB
-rw-r--r--
pipes.py
8.707 KB
-rw-r--r--
pkgutil.py
20.718 KB
-rw-r--r--
platform.py
45.665 KB
-rwxr-xr-x
plistlib.py
31.046 KB
-rw-r--r--
poplib.py
13.983 KB
-rw-r--r--
posixpath.py
13.133 KB
-rw-r--r--
pprint.py
14.569 KB
-rw-r--r--
profile.py
21.516 KB
-rwxr-xr-x
pstats.py
25.699 KB
-rw-r--r--
pty.py
4.651 KB
-rw-r--r--
py_compile.py
6.937 KB
-rw-r--r--
pyclbr.py
13.203 KB
-rw-r--r--
pydoc.py
100.597 KB
-rwxr-xr-x
queue.py
8.628 KB
-rw-r--r--
quopri.py
7.095 KB
-rwxr-xr-x
random.py
25.473 KB
-rw-r--r--
re.py
15.238 KB
-rw-r--r--
reprlib.py
4.99 KB
-rw-r--r--
rlcompleter.py
5.927 KB
-rw-r--r--
runpy.py
10.563 KB
-rw-r--r--
sched.py
6.205 KB
-rw-r--r--
selectors.py
16.696 KB
-rw-r--r--
shelve.py
8.328 KB
-rw-r--r--
shlex.py
11.277 KB
-rw-r--r--
shutil.py
38.967 KB
-rw-r--r--
site.py
21.048 KB
-rw-r--r--
smtpd.py
29.288 KB
-rwxr-xr-x
smtplib.py
38.058 KB
-rwxr-xr-x
sndhdr.py
6.109 KB
-rw-r--r--
socket.py
18.62 KB
-rw-r--r--
socketserver.py
23.801 KB
-rw-r--r--
sre_compile.py
19.437 KB
-rw-r--r--
sre_constants.py
7.097 KB
-rw-r--r--
sre_parse.py
30.692 KB
-rw-r--r--
ssl.py
33.933 KB
-rw-r--r--
stat.py
4.297 KB
-rw-r--r--
statistics.py
19.098 KB
-rw-r--r--
string.py
11.177 KB
-rw-r--r--
stringprep.py
12.614 KB
-rw-r--r--
struct.py
0.251 KB
-rw-r--r--
subprocess.py
63.036 KB
-rw-r--r--
sunau.py
17.671 KB
-rw-r--r--
symbol.py
2.005 KB
-rwxr-xr-x
symtable.py
7.23 KB
-rw-r--r--
sysconfig.py
24.055 KB
-rw-r--r--
tabnanny.py
11.143 KB
-rwxr-xr-x
tarfile.py
89.411 KB
-rwxr-xr-x
telnetlib.py
22.533 KB
-rw-r--r--
tempfile.py
21.997 KB
-rw-r--r--
textwrap.py
18.83 KB
-rw-r--r--
this.py
0.979 KB
-rw-r--r--
threading.py
47.658 KB
-rw-r--r--
timeit.py
11.691 KB
-rwxr-xr-x
token.py
2.963 KB
-rw-r--r--
tokenize.py
24.996 KB
-rw-r--r--
trace.py
30.749 KB
-rwxr-xr-x
traceback.py
10.905 KB
-rw-r--r--
tracemalloc.py
15.284 KB
-rw-r--r--
tty.py
0.858 KB
-rw-r--r--
types.py
5.284 KB
-rw-r--r--
uu.py
6.607 KB
-rwxr-xr-x
uuid.py
23.168 KB
-rw-r--r--
warnings.py
13.968 KB
-rw-r--r--
wave.py
17.268 KB
-rw-r--r--
weakref.py
18.93 KB
-rw-r--r--
webbrowser.py
20.93 KB
-rwxr-xr-x
xdrlib.py
5.774 KB
-rw-r--r--
zipfile.py
66.94 KB
-rw-r--r--