Current Path: > > opt > alt > python-internal > lib64 > > > python3.11 > >
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
asyncio | Directory | - | - | |
collections | Directory | - | - | |
concurrent | Directory | - | - | |
config-3.11-x86_64-linux-gnu | Directory | - | - | |
ctypes | Directory | - | - | |
curses | Directory | - | - | |
dbm | Directory | - | - | |
distutils | Directory | - | - | |
Directory | - | - | ||
encodings | Directory | - | - | |
ensurepip | Directory | - | - | |
html | Directory | - | - | |
http | Directory | - | - | |
importlib | Directory | - | - | |
json | Directory | - | - | |
lib-dynload | Directory | - | - | |
lib2to3 | Directory | - | - | |
logging | Directory | - | - | |
multiprocessing | Directory | - | - | |
pydoc_data | Directory | - | - | |
re | Directory | - | - | |
site-packages | Directory | - | - | |
sqlite3 | Directory | - | - | |
tomllib | Directory | - | - | |
unittest | Directory | - | - | |
urllib | Directory | - | - | |
venv | Directory | - | - | |
wsgiref | Directory | - | - | |
xml | Directory | - | - | |
xmlrpc | Directory | - | - | |
zoneinfo | Directory | - | - | |
LICENSE.txt | File | 13936 bytes | June 03 2025 18:38:25. | |
__future__.py | File | 5218 bytes | June 03 2025 18:38:25. | |
__hello__.py | File | 227 bytes | June 03 2025 18:38:25. | |
_aix_support.py | File | 3389 bytes | June 03 2025 18:38:25. | |
_bootsubprocess.py | File | 2675 bytes | June 03 2025 18:38:25. | |
_collections_abc.py | File | 30193 bytes | June 03 2025 18:38:25. | |
_compat_pickle.py | File | 8761 bytes | June 03 2025 18:38:25. | |
_compression.py | File | 5681 bytes | June 03 2025 18:38:25. | |
_markupbase.py | File | 14653 bytes | June 03 2025 18:38:25. | |
_osx_support.py | File | 22023 bytes | June 03 2025 18:38:25. | |
_py_abc.py | File | 6189 bytes | June 03 2025 18:38:25. | |
_pydecimal.py | File | 229202 bytes | June 03 2025 18:38:25. | |
_pyio.py | File | 94193 bytes | June 03 2025 18:38:25. | |
_sitebuiltins.py | File | 3128 bytes | June 03 2025 18:38:25. | |
_strptime.py | File | 25175 bytes | June 03 2025 18:38:25. | |
_sysconfigdata__linux_x86_64-linux-gnu.py | File | 59345 bytes | July 23 2025 10:03:07. | |
_sysconfigdata_d_linux_x86_64-linux-gnu.py | File | 58569 bytes | July 23 2025 09:46:47. | |
_threading_local.py | File | 7220 bytes | June 03 2025 18:38:25. | |
_weakrefset.py | File | 5893 bytes | June 03 2025 18:38:25. | |
abc.py | File | 6538 bytes | June 03 2025 18:38:25. | |
aifc.py | File | 34211 bytes | June 03 2025 18:38:25. | |
antigravity.py | File | 500 bytes | June 03 2025 18:38:25. | |
argparse.py | File | 100283 bytes | June 03 2025 18:38:25. | |
ast.py | File | 61444 bytes | June 03 2025 18:38:25. | |
asynchat.py | File | 11570 bytes | June 03 2025 18:38:25. | |
asyncore.py | File | 20310 bytes | June 03 2025 18:38:25. | |
base64.py | File | 21047 bytes | June 03 2025 18:38:25. | |
bdb.py | File | 32463 bytes | June 03 2025 18:38:25. | |
bisect.py | File | 3135 bytes | June 03 2025 18:38:25. | |
bz2.py | File | 11847 bytes | June 03 2025 18:38:25. | |
cProfile.py | File | 6365 bytes | June 03 2025 18:38:25. | |
calendar.py | File | 24731 bytes | June 03 2025 18:38:25. | |
cgi.py | File | 34438 bytes | June 03 2025 18:38:25. | |
cgitb.py | File | 12421 bytes | June 03 2025 18:38:25. | |
chunk.py | File | 5500 bytes | June 03 2025 18:38:25. | |
cmd.py | File | 14873 bytes | June 03 2025 18:38:25. | |
code.py | File | 10622 bytes | June 03 2025 18:38:25. | |
codecs.py | File | 37150 bytes | June 03 2025 18:38:25. | |
codeop.py | File | 5907 bytes | June 03 2025 18:38:25. | |
colorsys.py | File | 4062 bytes | June 03 2025 18:38:25. | |
compileall.py | File | 20252 bytes | June 03 2025 18:38:25. | |
configparser.py | File | 55660 bytes | June 03 2025 18:38:25. | |
contextlib.py | File | 27414 bytes | June 03 2025 18:38:25. | |
contextvars.py | File | 129 bytes | June 03 2025 18:38:25. | |
copy.py | File | 8681 bytes | June 03 2025 18:38:25. | |
copyreg.py | File | 7677 bytes | June 03 2025 18:38:25. | |
crypt.py | File | 3913 bytes | June 03 2025 18:38:25. | |
csv.py | File | 16030 bytes | June 03 2025 18:38:25. | |
dataclasses.py | File | 58472 bytes | June 03 2025 18:38:25. | |
datetime.py | File | 91832 bytes | June 03 2025 18:38:25. | |
decimal.py | File | 320 bytes | June 03 2025 18:38:25. | |
difflib.py | File | 83308 bytes | June 03 2025 18:38:25. | |
dis.py | File | 28906 bytes | June 03 2025 18:38:25. | |
doctest.py | File | 106297 bytes | June 03 2025 18:38:25. | |
enum.py | File | 79583 bytes | June 03 2025 18:38:25. | |
filecmp.py | File | 10178 bytes | June 03 2025 18:38:25. | |
fileinput.py | File | 15714 bytes | June 03 2025 18:38:25. | |
fnmatch.py | File | 5999 bytes | June 03 2025 18:38:25. | |
fractions.py | File | 28677 bytes | June 03 2025 18:38:25. | |
ftplib.py | File | 35815 bytes | June 03 2025 18:38:25. | |
functools.py | File | 38413 bytes | June 03 2025 18:38:25. | |
genericpath.py | File | 5246 bytes | June 03 2025 18:38:25. | |
getopt.py | File | 7489 bytes | June 03 2025 18:38:25. | |
getpass.py | File | 5990 bytes | June 03 2025 18:38:25. | |
gettext.py | File | 21320 bytes | June 03 2025 18:38:25. | |
glob.py | File | 8732 bytes | June 03 2025 18:38:25. | |
graphlib.py | File | 9656 bytes | June 03 2025 18:38:25. | |
gzip.py | File | 24074 bytes | June 03 2025 18:38:25. | |
hashlib.py | File | 11765 bytes | June 03 2025 18:38:25. | |
heapq.py | File | 23024 bytes | June 03 2025 18:38:25. | |
hmac.py | File | 7716 bytes | June 03 2025 18:38:25. | |
imaplib.py | File | 55217 bytes | June 03 2025 18:38:25. | |
imghdr.py | File | 3952 bytes | June 03 2025 18:38:25. | |
imp.py | File | 10606 bytes | June 03 2025 18:38:25. | |
inspect.py | File | 123419 bytes | June 03 2025 18:38:25. | |
io.py | File | 4320 bytes | June 03 2025 18:38:25. | |
ipaddress.py | File | 81414 bytes | June 03 2025 18:38:25. | |
keyword.py | File | 1061 bytes | June 03 2025 18:38:25. | |
linecache.py | File | 5649 bytes | June 03 2025 18:38:25. | |
locale.py | File | 79095 bytes | June 03 2025 18:38:25. | |
lzma.py | File | 13277 bytes | June 03 2025 18:38:25. | |
mailbox.py | File | 78830 bytes | June 03 2025 18:38:25. | |
mailcap.py | File | 9369 bytes | June 03 2025 18:38:25. | |
mimetypes.py | File | 22962 bytes | June 03 2025 18:38:25. | |
modulefinder.py | File | 23699 bytes | June 03 2025 18:38:25. | |
netrc.py | File | 6929 bytes | June 03 2025 18:38:25. | |
nntplib.py | File | 41087 bytes | June 03 2025 18:38:25. | |
ntpath.py | File | 30686 bytes | June 03 2025 18:38:25. | |
nturl2path.py | File | 2887 bytes | June 03 2025 18:38:25. | |
numbers.py | File | 10348 bytes | June 03 2025 18:38:25. | |
opcode.py | File | 10447 bytes | June 03 2025 18:38:25. | |
operator.py | File | 10965 bytes | June 03 2025 18:38:25. | |
optparse.py | File | 60369 bytes | June 03 2025 18:38:25. | |
os.py | File | 39530 bytes | June 03 2025 18:38:25. | |
pathlib.py | File | 48566 bytes | June 03 2025 18:38:25. | |
pdb.py | File | 64192 bytes | June 03 2025 18:38:25. | |
pickle.py | File | 65132 bytes | June 03 2025 18:38:25. | |
pickletools.py | File | 93861 bytes | June 03 2025 18:38:25. | |
pipes.py | File | 8978 bytes | June 03 2025 18:38:25. | |
pkgutil.py | File | 24638 bytes | June 03 2025 18:38:25. | |
platform.py | File | 42293 bytes | June 03 2025 18:38:25. | |
plistlib.py | File | 28354 bytes | June 03 2025 18:38:25. | |
poplib.py | File | 15198 bytes | June 03 2025 18:38:25. | |
posixpath.py | File | 17199 bytes | June 03 2025 18:38:25. | |
pprint.py | File | 24583 bytes | June 03 2025 18:38:25. | |
profile.py | File | 22902 bytes | June 03 2025 18:38:25. | |
pstats.py | File | 29356 bytes | June 03 2025 18:38:25. | |
pty.py | File | 6317 bytes | June 03 2025 18:38:25. | |
py_compile.py | File | 7837 bytes | June 03 2025 18:38:25. | |
pyclbr.py | File | 11396 bytes | June 03 2025 18:38:25. | |
pydoc.py | File | 112670 bytes | June 03 2025 18:38:25. | |
queue.py | File | 11496 bytes | June 03 2025 18:38:25. | |
quopri.py | File | 7287 bytes | June 03 2025 18:38:25. | |
random.py | File | 32162 bytes | June 03 2025 18:38:25. | |
reprlib.py | File | 5437 bytes | June 03 2025 18:38:25. | |
rlcompleter.py | File | 7827 bytes | June 03 2025 18:38:25. | |
runpy.py | File | 13159 bytes | June 03 2025 18:38:25. | |
sched.py | File | 6351 bytes | June 03 2025 18:38:25. | |
secrets.py | File | 2028 bytes | June 03 2025 18:38:25. | |
selectors.py | File | 19671 bytes | June 03 2025 18:38:25. | |
shelve.py | File | 8560 bytes | June 03 2025 18:38:25. | |
shlex.py | File | 13501 bytes | June 03 2025 18:38:25. | |
shutil.py | File | 56517 bytes | June 03 2025 18:38:25. | |
signal.py | File | 2495 bytes | June 03 2025 18:38:25. | |
site.py | File | 22987 bytes | June 03 2025 18:38:25. | |
smtpd.py | File | 31181 bytes | June 03 2025 18:38:25. | |
smtplib.py | File | 45437 bytes | June 03 2025 18:38:25. | |
sndhdr.py | File | 7448 bytes | June 03 2025 18:38:25. | |
socket.py | File | 37557 bytes | June 03 2025 18:38:25. | |
socketserver.py | File | 27586 bytes | June 03 2025 18:38:25. | |
sre_compile.py | File | 231 bytes | June 03 2025 18:38:25. | |
sre_constants.py | File | 232 bytes | June 03 2025 18:38:25. | |
sre_parse.py | File | 229 bytes | June 03 2025 18:38:25. | |
ssl.py | File | 54305 bytes | June 03 2025 18:38:25. | |
stat.py | File | 5485 bytes | June 03 2025 18:38:25. | |
statistics.py | File | 47705 bytes | June 03 2025 18:38:25. | |
string.py | File | 11786 bytes | June 03 2025 18:38:25. | |
stringprep.py | File | 12917 bytes | June 03 2025 18:38:25. | |
struct.py | File | 257 bytes | June 03 2025 18:38:25. | |
subprocess.py | File | 88725 bytes | June 03 2025 18:38:25. | |
sunau.py | File | 18480 bytes | June 03 2025 18:38:25. | |
symtable.py | File | 10368 bytes | June 03 2025 18:38:25. | |
sysconfig.py | File | 30315 bytes | June 03 2025 18:38:25. | |
tabnanny.py | File | 11318 bytes | June 03 2025 18:38:25. | |
tarfile.py | File | 111838 bytes | June 03 2025 18:38:25. | |
telnetlib.py | File | 23301 bytes | June 03 2025 18:38:25. | |
tempfile.py | File | 31873 bytes | June 03 2025 18:38:25. | |
textwrap.py | File | 19718 bytes | June 03 2025 18:38:25. | |
this.py | File | 1003 bytes | June 03 2025 18:38:25. | |
threading.py | File | 58231 bytes | June 03 2025 18:38:25. | |
timeit.py | File | 13538 bytes | June 03 2025 18:38:25. | |
token.py | File | 2386 bytes | June 03 2025 18:38:25. | |
tokenize.py | File | 26336 bytes | June 03 2025 18:38:25. | |
trace.py | File | 29202 bytes | June 03 2025 18:38:25. | |
traceback.py | File | 40547 bytes | June 03 2025 18:38:25. | |
tracemalloc.py | File | 18047 bytes | June 03 2025 18:38:25. | |
tty.py | File | 879 bytes | June 03 2025 18:38:25. | |
types.py | File | 10067 bytes | June 03 2025 18:38:25. | |
typing.py | File | 120951 bytes | June 03 2025 18:38:25. | |
uu.py | File | 7341 bytes | July 23 2025 10:03:41. | |
uuid.py | File | 27597 bytes | June 03 2025 18:38:25. | |
warnings.py | File | 21110 bytes | June 03 2025 18:38:25. | |
wave.py | File | 21818 bytes | June 03 2025 18:38:25. | |
weakref.py | File | 21513 bytes | June 03 2025 18:38:25. | |
webbrowser.py | File | 25155 bytes | June 03 2025 18:38:25. | |
xdrlib.py | File | 5977 bytes | June 03 2025 18:38:25. | |
zipapp.py | File | 7535 bytes | June 03 2025 18:38:25. | |
zipfile.py | File | 93788 bytes | June 03 2025 18:38:25. | |
zipimport.py | File | 30897 bytes | June 03 2025 18:38:25. |
"""Helper class to quickly write a loop over all standard input files. Typical use is: import fileinput for line in fileinput.input(encoding="utf-8"): process(line) This iterates over the lines of all files listed in sys.argv[1:], defaulting to sys.stdin if the list is empty. If a filename is '-' it is also replaced by sys.stdin and the optional arguments mode and openhook are ignored. To specify an alternative list of filenames, pass it as the argument to input(). A single file name is also allowed. Functions filename(), lineno() return the filename and cumulative line number of the line that has just been read; filelineno() returns its line number in the current file; isfirstline() returns true iff the line just read is the first line of its file; isstdin() returns true iff the line was read from sys.stdin. Function nextfile() closes the current file so that the next iteration will read the first line from the next file (if any); lines not read from the file will not count towards the cumulative line count; the filename is not changed until after the first line of the next file has been read. Function close() closes the sequence. Before any lines have been read, filename() returns None and both line numbers are zero; nextfile() has no effect. After all lines have been read, filename() and the line number functions return the values pertaining to the last line read; nextfile() has no effect. All files are opened in text mode by default, you can override this by setting the mode parameter to input() or FileInput.__init__(). If an I/O error occurs during opening or reading a file, the OSError exception is raised. If sys.stdin is used more than once, the second and further use will return no lines, except perhaps for interactive use, or if it has been explicitly reset (e.g. using sys.stdin.seek(0)). Empty files are opened and immediately closed; the only time their presence in the list of filenames is noticeable at all is when the last file opened is empty. It is possible that the last line of a file doesn't end in a newline character; otherwise lines are returned including the trailing newline. Class FileInput is the implementation; its methods filename(), lineno(), fileline(), isfirstline(), isstdin(), nextfile() and close() correspond to the functions in the module. In addition it has a readline() method which returns the next input line, and a __getitem__() method which implements the sequence behavior. The sequence must be accessed in strictly sequential order; sequence access and readline() cannot be mixed. Optional in-place filtering: if the keyword argument inplace=1 is passed to input() or to the FileInput constructor, the file is moved to a backup file and standard output is directed to the input file. This makes it possible to write a filter that rewrites its input file in place. If the keyword argument backup=".<some extension>" is also given, it specifies the extension for the backup file, and the backup file remains around; by default, the extension is ".bak" and it is deleted when the output file is closed. In-place filtering is disabled when standard input is read. XXX The current implementation does not work for MS-DOS 8+3 filesystems. """ import io import sys, os from types import GenericAlias __all__ = ["input", "close", "nextfile", "filename", "lineno", "filelineno", "fileno", "isfirstline", "isstdin", "FileInput", "hook_compressed", "hook_encoded"] _state = None def input(files=None, inplace=False, backup="", *, mode="r", openhook=None, encoding=None, errors=None): """Return an instance of the FileInput class, which can be iterated. The parameters are passed to the constructor of the FileInput class. The returned instance, in addition to being an iterator, keeps global state for the functions of this module,. """ global _state if _state and _state._file: raise RuntimeError("input() already active") _state = FileInput(files, inplace, backup, mode=mode, openhook=openhook, encoding=encoding, errors=errors) return _state def close(): """Close the sequence.""" global _state state = _state _state = None if state: state.close() def nextfile(): """ Close the current file so that the next iteration will read the first line from the next file (if any); lines not read from the file will not count towards the cumulative line count. The filename is not changed until after the first line of the next file has been read. Before the first line has been read, this function has no effect; it cannot be used to skip the first file. After the last line of the last file has been read, this function has no effect. """ if not _state: raise RuntimeError("no active input()") return _state.nextfile() def filename(): """ Return the name of the file currently being read. Before the first line has been read, returns None. """ if not _state: raise RuntimeError("no active input()") return _state.filename() def lineno(): """ Return the cumulative line number of the line that has just been read. Before the first line has been read, returns 0. After the last line of the last file has been read, returns the line number of that line. """ if not _state: raise RuntimeError("no active input()") return _state.lineno() def filelineno(): """ Return the line number in the current file. Before the first line has been read, returns 0. After the last line of the last file has been read, returns the line number of that line within the file. """ if not _state: raise RuntimeError("no active input()") return _state.filelineno() def fileno(): """ Return the file number of the current file. When no file is currently opened, returns -1. """ if not _state: raise RuntimeError("no active input()") return _state.fileno() def isfirstline(): """ Returns true the line just read is the first line of its file, otherwise returns false. """ if not _state: raise RuntimeError("no active input()") return _state.isfirstline() def isstdin(): """ Returns true if the last line was read from sys.stdin, otherwise returns false. """ if not _state: raise RuntimeError("no active input()") return _state.isstdin() class FileInput: """FileInput([files[, inplace[, backup]]], *, mode=None, openhook=None) Class FileInput is the implementation of the module; its methods filename(), lineno(), fileline(), isfirstline(), isstdin(), fileno(), nextfile() and close() correspond to the functions of the same name in the module. In addition it has a readline() method which returns the next input line, and a __getitem__() method which implements the sequence behavior. The sequence must be accessed in strictly sequential order; random access and readline() cannot be mixed. """ def __init__(self, files=None, inplace=False, backup="", *, mode="r", openhook=None, encoding=None, errors=None): if isinstance(files, str): files = (files,) elif isinstance(files, os.PathLike): files = (os.fspath(files), ) else: if files is None: files = sys.argv[1:] if not files: files = ('-',) else: files = tuple(files) self._files = files self._inplace = inplace self._backup = backup self._savestdout = None self._output = None self._filename = None self._startlineno = 0 self._filelineno = 0 self._file = None self._isstdin = False self._backupfilename = None self._encoding = encoding self._errors = errors # We can not use io.text_encoding() here because old openhook doesn't # take encoding parameter. if (sys.flags.warn_default_encoding and "b" not in mode and encoding is None and openhook is None): import warnings warnings.warn("'encoding' argument not specified.", EncodingWarning, 2) # restrict mode argument to reading modes if mode not in ('r', 'rb'): raise ValueError("FileInput opening mode must be 'r' or 'rb'") self._mode = mode self._write_mode = mode.replace('r', 'w') if openhook: if inplace: raise ValueError("FileInput cannot use an opening hook in inplace mode") if not callable(openhook): raise ValueError("FileInput openhook must be callable") self._openhook = openhook def __del__(self): self.close() def close(self): try: self.nextfile() finally: self._files = () def __enter__(self): return self def __exit__(self, type, value, traceback): self.close() def __iter__(self): return self def __next__(self): while True: line = self._readline() if line: self._filelineno += 1 return line if not self._file: raise StopIteration self.nextfile() # repeat with next file def nextfile(self): savestdout = self._savestdout self._savestdout = None if savestdout: sys.stdout = savestdout output = self._output self._output = None try: if output: output.close() finally: file = self._file self._file = None try: del self._readline # restore FileInput._readline except AttributeError: pass try: if file and not self._isstdin: file.close() finally: backupfilename = self._backupfilename self._backupfilename = None if backupfilename and not self._backup: try: os.unlink(backupfilename) except OSError: pass self._isstdin = False def readline(self): while True: line = self._readline() if line: self._filelineno += 1 return line if not self._file: return line self.nextfile() # repeat with next file def _readline(self): if not self._files: if 'b' in self._mode: return b'' else: return '' self._filename = self._files[0] self._files = self._files[1:] self._startlineno = self.lineno() self._filelineno = 0 self._file = None self._isstdin = False self._backupfilename = 0 # EncodingWarning is emitted in __init__() already if "b" not in self._mode: encoding = self._encoding or "locale" else: encoding = None if self._filename == '-': self._filename = '<stdin>' if 'b' in self._mode: self._file = getattr(sys.stdin, 'buffer', sys.stdin) else: self._file = sys.stdin self._isstdin = True else: if self._inplace: self._backupfilename = ( os.fspath(self._filename) + (self._backup or ".bak")) try: os.unlink(self._backupfilename) except OSError: pass # The next few lines may raise OSError os.rename(self._filename, self._backupfilename) self._file = open(self._backupfilename, self._mode, encoding=encoding, errors=self._errors) try: perm = os.fstat(self._file.fileno()).st_mode except OSError: self._output = open(self._filename, self._write_mode, encoding=encoding, errors=self._errors) else: mode = os.O_CREAT | os.O_WRONLY | os.O_TRUNC if hasattr(os, 'O_BINARY'): mode |= os.O_BINARY fd = os.open(self._filename, mode, perm) self._output = os.fdopen(fd, self._write_mode, encoding=encoding, errors=self._errors) try: os.chmod(self._filename, perm) except OSError: pass self._savestdout = sys.stdout sys.stdout = self._output else: # This may raise OSError if self._openhook: # Custom hooks made previous to Python 3.10 didn't have # encoding argument if self._encoding is None: self._file = self._openhook(self._filename, self._mode) else: self._file = self._openhook( self._filename, self._mode, encoding=self._encoding, errors=self._errors) else: self._file = open(self._filename, self._mode, encoding=encoding, errors=self._errors) self._readline = self._file.readline # hide FileInput._readline return self._readline() def filename(self): return self._filename def lineno(self): return self._startlineno + self._filelineno def filelineno(self): return self._filelineno def fileno(self): if self._file: try: return self._file.fileno() except ValueError: return -1 else: return -1 def isfirstline(self): return self._filelineno == 1 def isstdin(self): return self._isstdin __class_getitem__ = classmethod(GenericAlias) def hook_compressed(filename, mode, *, encoding=None, errors=None): if encoding is None and "b" not in mode: # EncodingWarning is emitted in FileInput() already. encoding = "locale" ext = os.path.splitext(filename)[1] if ext == '.gz': import gzip stream = gzip.open(filename, mode) elif ext == '.bz2': import bz2 stream = bz2.BZ2File(filename, mode) else: return open(filename, mode, encoding=encoding, errors=errors) # gzip and bz2 are binary mode by default. if "b" not in mode: stream = io.TextIOWrapper(stream, encoding=encoding, errors=errors) return stream def hook_encoded(encoding, errors=None): def openhook(filename, mode): return open(filename, mode, encoding=encoding, errors=errors) return openhook def _test(): import getopt inplace = False backup = False opts, args = getopt.getopt(sys.argv[1:], "ib:") for o, a in opts: if o == '-i': inplace = True if o == '-b': backup = a for line in input(args, inplace=inplace, backup=backup): if line[-1:] == '\n': line = line[:-1] if line[-1:] == '\r': line = line[:-1] print("%d: %s[%d]%s %s" % (lineno(), filename(), filelineno(), isfirstline() and "*" or "", line)) print("%d: %s[%d]" % (lineno(), filename(), filelineno())) if __name__ == '__main__': _test()
SILENT KILLER Tool