Linux server1.hosting4iran.com 4.18.0-553.123.2.el8_10.x86_64 #1 SMP Thu May 7 15:28:41 EDT 2026 x86_64
LiteSpeed
Server IP : 185.208.174.156 & Your IP : 216.73.216.67
Domains : 318 Domain
User : satitravel
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
share /
doc /
python2-docs /
html /
library /
Delete
Unzip
Name
Size
Permission
Date
Action
2to3.html
58.11
KB
-rw-r--r--
2019-03-27 12:19
__builtin__.html
10.81
KB
-rw-r--r--
2019-03-27 12:19
__future__.html
14.34
KB
-rw-r--r--
2019-03-27 12:19
__main__.html
7.34
KB
-rw-r--r--
2019-03-27 12:19
_winreg.html
63.12
KB
-rw-r--r--
2019-03-27 12:19
abc.html
25.22
KB
-rw-r--r--
2019-03-27 12:19
aepack.html
13.83
KB
-rw-r--r--
2019-03-27 12:19
aetools.html
16
KB
-rw-r--r--
2019-03-27 12:19
aetypes.html
20.53
KB
-rw-r--r--
2019-03-27 12:19
aifc.html
24.48
KB
-rw-r--r--
2019-03-27 12:19
al.html
18.23
KB
-rw-r--r--
2019-03-27 12:19
allos.html
34.47
KB
-rw-r--r--
2019-03-27 12:19
anydbm.html
17.7
KB
-rw-r--r--
2019-03-27 12:19
archiving.html
9.84
KB
-rw-r--r--
2019-03-27 12:19
argparse.html
257.44
KB
-rw-r--r--
2019-03-27 12:19
array.html
31.11
KB
-rw-r--r--
2019-03-27 12:19
ast.html
37.27
KB
-rw-r--r--
2019-03-27 12:19
asynchat.html
33.13
KB
-rw-r--r--
2019-03-27 12:19
asyncore.html
39.68
KB
-rw-r--r--
2019-03-27 12:19
atexit.html
18.02
KB
-rw-r--r--
2019-03-27 12:19
audioop.html
33.45
KB
-rw-r--r--
2019-03-27 12:19
autogil.html
8.53
KB
-rw-r--r--
2019-03-27 12:19
base64.html
21.35
KB
-rw-r--r--
2019-03-27 12:19
basehttpserver.html
36.56
KB
-rw-r--r--
2019-03-27 12:19
bastion.html
11.52
KB
-rw-r--r--
2019-03-27 12:19
bdb.html
40.42
KB
-rw-r--r--
2019-03-27 12:19
binascii.html
22.46
KB
-rw-r--r--
2019-03-27 12:19
binhex.html
11.04
KB
-rw-r--r--
2019-03-27 12:19
bisect.html
24.09
KB
-rw-r--r--
2019-03-27 12:19
bsddb.html
27.92
KB
-rw-r--r--
2019-03-27 12:19
bz2.html
28.37
KB
-rw-r--r--
2019-03-27 12:19
calendar.html
40.78
KB
-rw-r--r--
2019-03-27 12:19
carbon.html
50.78
KB
-rw-r--r--
2019-03-27 12:19
cd.html
29.33
KB
-rw-r--r--
2019-03-27 12:19
cgi.html
54.61
KB
-rw-r--r--
2019-03-27 12:19
cgihttpserver.html
13.7
KB
-rw-r--r--
2019-03-27 12:19
cgitb.html
11.98
KB
-rw-r--r--
2019-03-27 12:19
chunk.html
15.53
KB
-rw-r--r--
2019-03-27 12:19
cmath.html
27.7
KB
-rw-r--r--
2019-03-27 12:19
cmd.html
28.36
KB
-rw-r--r--
2019-03-27 12:19
code.html
26.33
KB
-rw-r--r--
2019-03-27 12:19
codecs.html
115.49
KB
-rw-r--r--
2019-03-27 12:19
codeop.html
15.53
KB
-rw-r--r--
2019-03-27 12:19
collections.html
144.19
KB
-rw-r--r--
2019-03-27 12:19
colorpicker.html
7.85
KB
-rw-r--r--
2019-03-27 12:19
colorsys.html
11.64
KB
-rw-r--r--
2019-03-27 12:19
commands.html
15.15
KB
-rw-r--r--
2019-03-27 12:19
compileall.html
18.18
KB
-rw-r--r--
2019-03-27 12:19
compiler.html
74.12
KB
-rw-r--r--
2019-03-27 12:19
configparser.html
66.16
KB
-rw-r--r--
2019-03-27 12:19
constants.html
13.65
KB
-rw-r--r--
2019-03-27 12:19
contextlib.html
22.24
KB
-rw-r--r--
2019-03-27 12:19
cookie.html
40.87
KB
-rw-r--r--
2019-03-27 12:19
cookielib.html
88.9
KB
-rw-r--r--
2019-03-27 12:19
copy.html
12.7
KB
-rw-r--r--
2019-03-27 12:19
copy_reg.html
14.35
KB
-rw-r--r--
2019-03-27 12:19
crypt.html
10.4
KB
-rw-r--r--
2019-03-27 12:19
crypto.html
7.58
KB
-rw-r--r--
2019-03-27 12:19
csv.html
74.66
KB
-rw-r--r--
2019-03-27 12:19
ctypes.html
258.37
KB
-rw-r--r--
2019-03-27 12:19
curses.ascii.html
24.29
KB
-rw-r--r--
2019-03-27 12:19
curses.html
163.58
KB
-rw-r--r--
2019-03-27 12:19
curses.panel.html
15.45
KB
-rw-r--r--
2019-03-27 12:19
custominterp.html
7.84
KB
-rw-r--r--
2019-03-27 12:19
datatypes.html
17.59
KB
-rw-r--r--
2019-03-27 12:19
datetime.html
247.5
KB
-rw-r--r--
2019-03-27 12:19
dbhash.html
16.43
KB
-rw-r--r--
2019-03-27 12:19
dbm.html
13.19
KB
-rw-r--r--
2019-03-27 12:19
debug.html
10.45
KB
-rw-r--r--
2019-03-27 12:19
decimal.html
217.1
KB
-rw-r--r--
2019-03-27 12:19
development.html
14.48
KB
-rw-r--r--
2019-03-27 12:19
difflib.html
89.82
KB
-rw-r--r--
2019-03-27 12:19
dircache.html
12.01
KB
-rw-r--r--
2019-03-27 12:19
dis.html
82.18
KB
-rw-r--r--
2019-03-27 12:19
distribution.html
7.5
KB
-rw-r--r--
2019-03-27 12:19
distutils.html
9.91
KB
-rw-r--r--
2019-03-27 12:19
dl.html
17.25
KB
-rw-r--r--
2019-03-27 12:19
doctest.html
181.53
KB
-rw-r--r--
2019-03-27 12:19
docxmlrpcserver.html
17.16
KB
-rw-r--r--
2019-03-27 12:19
dumbdbm.html
15.18
KB
-rw-r--r--
2019-03-27 12:19
dummy_thread.html
9.83
KB
-rw-r--r--
2019-03-27 12:19
dummy_threading.html
8.72
KB
-rw-r--r--
2019-03-27 12:19
easydialogs.html
32.35
KB
-rw-r--r--
2019-03-27 12:19
email-examples.html
46.31
KB
-rw-r--r--
2019-03-27 12:19
email.charset.html
28.73
KB
-rw-r--r--
2019-03-27 12:19
email.encoders.html
12.55
KB
-rw-r--r--
2019-03-27 12:19
email.errors.html
17.53
KB
-rw-r--r--
2019-03-27 12:19
email.generator.html
22.6
KB
-rw-r--r--
2019-03-27 12:19
email.header.html
28.43
KB
-rw-r--r--
2019-03-27 12:19
email.html
54.42
KB
-rw-r--r--
2019-03-27 12:19
email.iterators.html
12.33
KB
-rw-r--r--
2019-03-27 12:19
email.message.html
68.54
KB
-rw-r--r--
2019-03-27 12:19
email.mime.html
30.91
KB
-rw-r--r--
2019-03-27 12:19
email.parser.html
34.32
KB
-rw-r--r--
2019-03-27 12:19
email.utils.html
26.44
KB
-rw-r--r--
2019-03-27 12:19
ensurepip.html
17.9
KB
-rw-r--r--
2019-03-27 12:19
errno.html
39.3
KB
-rw-r--r--
2019-03-27 12:19
exceptions.html
62.2
KB
-rw-r--r--
2019-03-27 12:19
fcntl.html
25.63
KB
-rw-r--r--
2019-03-27 12:19
filecmp.html
23.43
KB
-rw-r--r--
2019-03-27 12:19
fileformats.html
9.43
KB
-rw-r--r--
2019-03-27 12:19
fileinput.html
26.44
KB
-rw-r--r--
2019-03-27 12:19
filesys.html
10.61
KB
-rw-r--r--
2019-03-27 12:19
fl.html
55.2
KB
-rw-r--r--
2019-03-27 12:19
fm.html
12.7
KB
-rw-r--r--
2019-03-27 12:19
fnmatch.html
15.88
KB
-rw-r--r--
2019-03-27 12:19
formatter.html
36.5
KB
-rw-r--r--
2019-03-27 12:19
fpectl.html
16.48
KB
-rw-r--r--
2019-03-27 12:19
fpformat.html
11.19
KB
-rw-r--r--
2019-03-27 12:19
fractions.html
24.3
KB
-rw-r--r--
2019-03-27 12:19
framework.html
36.07
KB
-rw-r--r--
2019-03-27 12:19
frameworks.html
7.37
KB
-rw-r--r--
2019-03-27 12:19
ftplib.html
48.42
KB
-rw-r--r--
2019-03-27 12:19
functions.html
200.82
KB
-rw-r--r--
2019-03-27 12:19
functools.html
28.95
KB
-rw-r--r--
2019-03-27 12:19
future_builtins.html
14.14
KB
-rw-r--r--
2019-03-27 12:19
gc.html
27.76
KB
-rw-r--r--
2019-03-27 12:19
gdbm.html
17.39
KB
-rw-r--r--
2019-03-27 12:19
gensuitemodule.html
12.28
KB
-rw-r--r--
2019-03-27 12:19
getopt.html
24.69
KB
-rw-r--r--
2019-03-27 12:19
getpass.html
11.16
KB
-rw-r--r--
2019-03-27 12:19
gettext.html
82.98
KB
-rw-r--r--
2019-03-27 12:19
gl.html
23.77
KB
-rw-r--r--
2019-03-27 12:19
glob.html
14.09
KB
-rw-r--r--
2019-03-27 12:19
grp.html
11.05
KB
-rw-r--r--
2019-03-27 12:19
gzip.html
20.09
KB
-rw-r--r--
2019-03-27 12:19
hashlib.html
24.87
KB
-rw-r--r--
2019-03-27 12:19
heapq.html
34.07
KB
-rw-r--r--
2019-03-27 12:19
hmac.html
14.04
KB
-rw-r--r--
2019-03-27 12:19
hotshot.html
19.67
KB
-rw-r--r--
2019-03-27 12:19
htmllib.html
27.03
KB
-rw-r--r--
2019-03-27 12:19
htmlparser.html
41.44
KB
-rw-r--r--
2019-03-27 12:19
httplib.html
69.27
KB
-rw-r--r--
2019-03-27 12:19
i18n.html
9.81
KB
-rw-r--r--
2019-03-27 12:19
ic.html
18.22
KB
-rw-r--r--
2019-03-27 12:19
idle.html
41.16
KB
-rw-r--r--
2019-03-27 12:19
imageop.html
15.72
KB
-rw-r--r--
2019-03-27 12:19
imaplib.html
57.14
KB
-rw-r--r--
2019-03-27 12:19
imgfile.html
12.43
KB
-rw-r--r--
2019-03-27 12:19
imghdr.html
11.95
KB
-rw-r--r--
2019-03-27 12:19
imp.html
36.72
KB
-rw-r--r--
2019-03-27 12:19
importlib.html
8.72
KB
-rw-r--r--
2019-03-27 12:19
imputil.html
32.78
KB
-rw-r--r--
2019-03-27 12:19
index.html
77.23
KB
-rw-r--r--
2019-03-27 12:19
inspect.html
55.49
KB
-rw-r--r--
2019-03-27 12:19
internet.html
25.53
KB
-rw-r--r--
2019-03-27 12:19
intro.html
9.13
KB
-rw-r--r--
2019-03-27 12:19
io.html
111.04
KB
-rw-r--r--
2019-03-27 12:19
ipc.html
16.21
KB
-rw-r--r--
2019-03-27 12:19
itertools.html
122.46
KB
-rw-r--r--
2019-03-27 12:19
jpeg.html
13.43
KB
-rw-r--r--
2019-03-27 12:19
json.html
71.95
KB
-rw-r--r--
2019-03-27 12:19
keyword.html
8.02
KB
-rw-r--r--
2019-03-27 12:19
language.html
11.41
KB
-rw-r--r--
2019-03-27 12:19
linecache.html
11.15
KB
-rw-r--r--
2019-03-27 12:19
locale.html
60.13
KB
-rw-r--r--
2019-03-27 12:19
logging.config.html
78.17
KB
-rw-r--r--
2019-03-27 12:19
logging.handlers.html
78.31
KB
-rw-r--r--
2019-03-27 12:19
logging.html
107.67
KB
-rw-r--r--
2019-03-27 12:19
mac.html
22.83
KB
-rw-r--r--
2019-03-27 12:19
macos.html
15.75
KB
-rw-r--r--
2019-03-27 12:19
macosa.html
13.75
KB
-rw-r--r--
2019-03-27 12:19
macostools.html
16.5
KB
-rw-r--r--
2019-03-27 12:19
macpath.html
8.19
KB
-rw-r--r--
2019-03-27 12:19
mailbox.html
167.11
KB
-rw-r--r--
2019-03-27 12:19
mailcap.html
13.8
KB
-rw-r--r--
2019-03-27 12:19
markup.html
19.4
KB
-rw-r--r--
2019-03-27 12:19
marshal.html
19
KB
-rw-r--r--
2019-03-27 12:19
math.html
42.98
KB
-rw-r--r--
2019-03-27 12:19
md5.html
14.77
KB
-rw-r--r--
2019-03-27 12:19
mhlib.html
23.56
KB
-rw-r--r--
2019-03-27 12:19
mimetools.html
20.71
KB
-rw-r--r--
2019-03-27 12:19
mimetypes.html
29.92
KB
-rw-r--r--
2019-03-27 12:19
mimewriter.html
15.7
KB
-rw-r--r--
2019-03-27 12:19
mimify.html
14.92
KB
-rw-r--r--
2019-03-27 12:19
miniaeframe.html
12.8
KB
-rw-r--r--
2019-03-27 12:19
misc.html
7.07
KB
-rw-r--r--
2019-03-27 12:19
mm.html
9.35
KB
-rw-r--r--
2019-03-27 12:19
mmap.html
30.11
KB
-rw-r--r--
2019-03-27 12:19
modulefinder.html
17.67
KB
-rw-r--r--
2019-03-27 12:19
modules.html
8.81
KB
-rw-r--r--
2019-03-27 12:19
msilib.html
56.5
KB
-rw-r--r--
2019-03-27 12:19
msvcrt.html
20.73
KB
-rw-r--r--
2019-03-27 12:19
multifile.html
25.64
KB
-rw-r--r--
2019-03-27 12:19
multiprocessing.html
404.82
KB
-rw-r--r--
2019-03-27 12:19
mutex.html
11.86
KB
-rw-r--r--
2019-03-27 12:19
netdata.html
17.95
KB
-rw-r--r--
2019-03-27 12:19
netrc.html
13.69
KB
-rw-r--r--
2019-03-27 12:19
new.html
12.87
KB
-rw-r--r--
2019-03-27 12:19
nis.html
11.23
KB
-rw-r--r--
2019-03-27 12:19
nntplib.html
44.62
KB
-rw-r--r--
2019-03-27 12:19
numbers.html
39.68
KB
-rw-r--r--
2019-03-27 12:19
numeric.html
13.96
KB
-rw-r--r--
2019-03-27 12:19
operator.html
91.43
KB
-rw-r--r--
2019-03-27 12:19
optparse.html
244.25
KB
-rw-r--r--
2019-03-27 12:19
os.html
234.57
KB
-rw-r--r--
2019-03-27 12:19
os.path.html
42.38
KB
-rw-r--r--
2019-03-27 12:19
ossaudiodev.html
44.53
KB
-rw-r--r--
2019-03-27 12:19
othergui.html
9.18
KB
-rw-r--r--
2019-03-27 12:19
parser.html
41.56
KB
-rw-r--r--
2019-03-27 12:19
pdb.html
37.7
KB
-rw-r--r--
2019-03-27 12:19
persistence.html
15.31
KB
-rw-r--r--
2019-03-27 12:19
pickle.html
107.11
KB
-rw-r--r--
2019-03-27 12:19
pickletools.html
11.21
KB
-rw-r--r--
2019-03-27 12:19
pipes.html
19.22
KB
-rw-r--r--
2019-03-27 12:19
pkgutil.html
26.73
KB
-rw-r--r--
2019-03-27 12:19
platform.html
30.86
KB
-rw-r--r--
2019-03-27 12:19
plistlib.html
17.91
KB
-rw-r--r--
2019-03-27 12:19
popen2.html
26.95
KB
-rw-r--r--
2019-03-27 12:19
poplib.html
23.75
KB
-rw-r--r--
2019-03-27 12:19
posix.html
16.24
KB
-rw-r--r--
2019-03-27 12:19
posixfile.html
20.89
KB
-rw-r--r--
2019-03-27 12:19
pprint.html
31.45
KB
-rw-r--r--
2019-03-27 12:19
profile.html
71.08
KB
-rw-r--r--
2019-03-27 12:19
pty.html
9.96
KB
-rw-r--r--
2019-03-27 12:19
pwd.html
12.1
KB
-rw-r--r--
2019-03-27 12:19
py_compile.html
11.65
KB
-rw-r--r--
2019-03-27 12:19
pyclbr.html
15.44
KB
-rw-r--r--
2019-03-27 12:19
pydoc.html
13.33
KB
-rw-r--r--
2019-03-27 12:19
pyexpat.html
78.99
KB
-rw-r--r--
2019-03-27 12:19
python.html
12.55
KB
-rw-r--r--
2019-03-27 12:19
queue.html
26.23
KB
-rw-r--r--
2019-03-27 12:19
quopri.html
12.44
KB
-rw-r--r--
2019-03-27 12:19
random.html
41.72
KB
-rw-r--r--
2019-03-27 12:19
re.html
152.33
KB
-rw-r--r--
2019-03-27 12:19
readline.html
36.51
KB
-rw-r--r--
2019-03-27 12:19
repr.html
21.27
KB
-rw-r--r--
2019-03-27 12:19
resource.html
27.62
KB
-rw-r--r--
2019-03-27 12:19
restricted.html
12.08
KB
-rw-r--r--
2019-03-27 12:19
rexec.html
39.62
KB
-rw-r--r--
2019-03-27 12:19
rfc822.html
45.32
KB
-rw-r--r--
2019-03-27 12:19
rlcompleter.html
14.12
KB
-rw-r--r--
2019-03-27 12:19
robotparser.html
13.09
KB
-rw-r--r--
2019-03-27 12:19
runpy.html
21.41
KB
-rw-r--r--
2019-03-27 12:19
sched.html
19.41
KB
-rw-r--r--
2019-03-27 12:19
scrolledtext.html
9.5
KB
-rw-r--r--
2019-03-27 12:19
select.html
43.06
KB
-rw-r--r--
2019-03-27 12:19
sets.html
39.21
KB
-rw-r--r--
2019-03-27 12:19
sgi.html
10.13
KB
-rw-r--r--
2019-03-27 12:19
sgmllib.html
33.66
KB
-rw-r--r--
2019-03-27 12:19
sha.html
12.76
KB
-rw-r--r--
2019-03-27 12:19
shelve.html
29.25
KB
-rw-r--r--
2019-03-27 12:19
shlex.html
34.21
KB
-rw-r--r--
2019-03-27 12:19
shutil.html
44.39
KB
-rw-r--r--
2019-03-27 12:19
signal.html
33.23
KB
-rw-r--r--
2019-03-27 12:19
simplehttpserver.html
19.87
KB
-rw-r--r--
2019-03-27 12:19
simplexmlrpcserver.html
36.91
KB
-rw-r--r--
2019-03-27 12:19
site.html
26.26
KB
-rw-r--r--
2019-03-27 12:19
smtpd.html
13.27
KB
-rw-r--r--
2019-03-27 12:19
smtplib.html
45.95
KB
-rw-r--r--
2019-03-27 12:19
sndhdr.html
10.74
KB
-rw-r--r--
2019-03-27 12:19
socket.html
113.69
KB
-rw-r--r--
2019-03-27 12:19
socketserver.html
74.64
KB
-rw-r--r--
2019-03-27 12:19
someos.html
16.09
KB
-rw-r--r--
2019-03-27 12:19
spwd.html
10.9
KB
-rw-r--r--
2019-03-27 12:19
sqlite3.html
146.5
KB
-rw-r--r--
2019-03-27 12:19
ssl.html
197.71
KB
-rw-r--r--
2019-03-27 12:19
stat.html
33.79
KB
-rw-r--r--
2019-03-27 12:19
statvfs.html
11.06
KB
-rw-r--r--
2019-03-27 12:19
stdtypes.html
291.16
KB
-rw-r--r--
2019-03-27 12:19
string.html
117.4
KB
-rw-r--r--
2019-03-27 12:19
stringio.html
19.59
KB
-rw-r--r--
2019-03-27 12:19
stringprep.html
17.31
KB
-rw-r--r--
2019-03-27 12:19
strings.html
15.53
KB
-rw-r--r--
2019-03-27 12:19
struct.html
43.84
KB
-rw-r--r--
2019-03-27 12:19
subprocess.html
107.86
KB
-rw-r--r--
2019-03-27 12:19
sun.html
7.08
KB
-rw-r--r--
2019-03-27 12:19
sunau.html
29.31
KB
-rw-r--r--
2019-03-27 12:19
sunaudio.html
18.79
KB
-rw-r--r--
2019-03-27 12:19
symbol.html
7.95
KB
-rw-r--r--
2019-03-27 12:19
symtable.html
25.26
KB
-rw-r--r--
2019-03-27 12:19
sys.html
108.39
KB
-rw-r--r--
2019-03-27 12:19
sysconfig.html
25.68
KB
-rw-r--r--
2019-03-27 12:19
syslog.html
19.27
KB
-rw-r--r--
2019-03-27 12:19
tabnanny.html
11.13
KB
-rw-r--r--
2019-03-27 12:19
tarfile.html
86.65
KB
-rw-r--r--
2019-03-27 12:19
telnetlib.html
27.13
KB
-rw-r--r--
2019-03-27 12:19
tempfile.html
31.16
KB
-rw-r--r--
2019-03-27 12:19
termios.html
16.9
KB
-rw-r--r--
2019-03-27 12:19
test.html
55.69
KB
-rw-r--r--
2019-03-27 12:19
textwrap.html
29.43
KB
-rw-r--r--
2019-03-27 12:19
thread.html
20.98
KB
-rw-r--r--
2019-03-27 12:19
threading.html
84.62
KB
-rw-r--r--
2019-03-27 12:19
time.html
62.3
KB
-rw-r--r--
2019-03-27 12:19
timeit.html
39.58
KB
-rw-r--r--
2019-03-27 12:19
tix.html
49.4
KB
-rw-r--r--
2019-03-27 12:19
tk.html
25.95
KB
-rw-r--r--
2019-03-27 12:19
tkinter.html
82.34
KB
-rw-r--r--
2019-03-27 12:19
token.html
20.51
KB
-rw-r--r--
2019-03-27 12:19
tokenize.html
20.12
KB
-rw-r--r--
2019-03-27 12:19
trace.html
28
KB
-rw-r--r--
2019-03-27 12:19
traceback.html
39.94
KB
-rw-r--r--
2019-03-27 12:19
ttk.html
105.97
KB
-rw-r--r--
2019-03-27 12:19
tty.html
9.52
KB
-rw-r--r--
2019-03-27 12:19
turtle.html
225.08
KB
-rw-r--r--
2019-03-27 12:19
types.html
29.13
KB
-rw-r--r--
2019-03-27 12:19
undoc.html
24.1
KB
-rw-r--r--
2019-03-27 12:19
unicodedata.html
19.71
KB
-rw-r--r--
2019-03-27 12:19
unittest.html
219.75
KB
-rw-r--r--
2019-03-27 12:19
unix.html
10.96
KB
-rw-r--r--
2019-03-27 12:19
urllib.html
66.67
KB
-rw-r--r--
2019-03-27 12:19
urllib2.html
110.72
KB
-rw-r--r--
2019-03-27 12:19
urlparse.html
42.46
KB
-rw-r--r--
2019-03-27 12:19
user.html
12.41
KB
-rw-r--r--
2019-03-27 12:19
userdict.html
31.32
KB
-rw-r--r--
2019-03-27 12:19
uu.html
11.53
KB
-rw-r--r--
2019-03-27 12:19
uuid.html
29.43
KB
-rw-r--r--
2019-03-27 12:19
warnings.html
49.76
KB
-rw-r--r--
2019-03-27 12:19
wave.html
24.31
KB
-rw-r--r--
2019-03-27 12:19
weakref.html
37.9
KB
-rw-r--r--
2019-03-27 12:19
webbrowser.html
25.94
KB
-rw-r--r--
2019-03-27 12:19
whichdb.html
9.28
KB
-rw-r--r--
2019-03-27 12:19
windows.html
9.59
KB
-rw-r--r--
2019-03-27 12:19
winsound.html
19.99
KB
-rw-r--r--
2019-03-27 12:19
wsgiref.html
86.31
KB
-rw-r--r--
2019-03-27 12:19
xdrlib.html
32.24
KB
-rw-r--r--
2019-03-27 12:19
xml.dom.html
95.58
KB
-rw-r--r--
2019-03-27 12:19
xml.dom.minidom.html
42.22
KB
-rw-r--r--
2019-03-27 12:19
xml.dom.pulldom.html
13.51
KB
-rw-r--r--
2019-03-27 12:19
xml.etree.elementtree.html
109.18
KB
-rw-r--r--
2019-03-27 12:19
xml.html
17.58
KB
-rw-r--r--
2019-03-27 12:19
xml.sax.handler.html
40.9
KB
-rw-r--r--
2019-03-27 12:19
xml.sax.html
22.91
KB
-rw-r--r--
2019-03-27 12:19
xml.sax.reader.html
43.75
KB
-rw-r--r--
2019-03-27 12:19
xml.sax.utils.html
15.71
KB
-rw-r--r--
2019-03-27 12:19
xmlrpclib.html
67.57
KB
-rw-r--r--
2019-03-27 12:19
zipfile.html
60.77
KB
-rw-r--r--
2019-03-27 12:19
zipimport.html
22.24
KB
-rw-r--r--
2019-03-27 12:19
zlib.html
30.5
KB
-rw-r--r--
2019-03-27 12:19
Save
Rename
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="X-UA-Compatible" content="IE=Edge" /> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>23.2. shlex — Simple lexical analysis — Python 2.7.16 documentation</title> <link rel="stylesheet" href="../_static/classic.css" type="text/css" /> <link rel="stylesheet" href="../_static/pygments.css" type="text/css" /> <script type="text/javascript" id="documentation_options" data-url_root="../" src="../_static/documentation_options.js"></script> <script type="text/javascript" src="../_static/jquery.js"></script> <script type="text/javascript" src="../_static/underscore.js"></script> <script type="text/javascript" src="../_static/doctools.js"></script> <script type="text/javascript" src="../_static/sidebar.js"></script> <link rel="search" type="application/opensearchdescription+xml" title="Search within Python 2.7.16 documentation" href="../_static/opensearch.xml"/> <link rel="author" title="About these documents" href="../about.html" /> <link rel="index" title="Index" href="../genindex.html" /> <link rel="search" title="Search" href="../search.html" /> <link rel="copyright" title="Copyright" href="../copyright.html" /> <link rel="next" title="24. Graphical User Interfaces with Tk" href="tk.html" /> <link rel="prev" title="23.1. cmd — Support for line-oriented command interpreters" href="cmd.html" /> <link rel="shortcut icon" type="image/png" href="../_static/py.png" /> <link rel="canonical" href="https://docs.python.org/2/library/shlex.html" /> <script type="text/javascript" src="../_static/copybutton.js"></script> </head><body> <div class="related" role="navigation" aria-label="related navigation"> <h3>Navigation</h3> <ul> <li class="right" style="margin-right: 10px"> <a href="../genindex.html" title="General Index" accesskey="I">index</a></li> <li class="right" > <a href="../py-modindex.html" title="Python Module Index" >modules</a> |</li> <li class="right" > <a href="tk.html" title="24. Graphical User Interfaces with Tk" accesskey="N">next</a> |</li> <li class="right" > <a href="cmd.html" title="23.1. cmd — Support for line-oriented command interpreters" accesskey="P">previous</a> |</li> <li><img src="../_static/py.png" alt="" style="vertical-align: middle; margin-top: -1px"/></li> <li><a href="https://www.python.org/">Python</a> »</li> <li> <a href="../index.html">Python 2.7.16 documentation</a> » </li> <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> »</li> <li class="nav-item nav-item-2"><a href="frameworks.html" accesskey="U">23. Program Frameworks</a> »</li> </ul> </div> <div class="document"> <div class="documentwrapper"> <div class="bodywrapper"> <div class="body" role="main"> <div class="section" id="module-shlex"> <span id="shlex-simple-lexical-analysis"></span><h1>23.2. <a class="reference internal" href="#module-shlex" title="shlex: Simple lexical analysis for Unix shell-like languages."><code class="xref py py-mod docutils literal notranslate"><span class="pre">shlex</span></code></a> — Simple lexical analysis<a class="headerlink" href="#module-shlex" title="Permalink to this headline">¶</a></h1> <div class="versionadded"> <p><span class="versionmodified">New in version 1.5.2.</span></p> </div> <p><strong>Source code:</strong> <a class="reference external" href="https://github.com/python/cpython/tree/2.7/Lib/shlex.py">Lib/shlex.py</a></p> <hr class="docutils" /> <p>The <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> class makes it easy to write lexical analyzers for simple syntaxes resembling that of the Unix shell. This will often be useful for writing minilanguages, (for example, in run control files for Python applications) or for parsing quoted strings.</p> <p>Prior to Python 2.7.3, this module did not support Unicode input.</p> <p>The <a class="reference internal" href="#module-shlex" title="shlex: Simple lexical analysis for Unix shell-like languages."><code class="xref py py-mod docutils literal notranslate"><span class="pre">shlex</span></code></a> module defines the following functions:</p> <dl class="function"> <dt id="shlex.split"> <code class="descclassname">shlex.</code><code class="descname">split</code><span class="sig-paren">(</span><em>s</em><span class="optional">[</span>, <em>comments</em><span class="optional">[</span>, <em>posix</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#shlex.split" title="Permalink to this definition">¶</a></dt> <dd><p>Split the string <em>s</em> using shell-like syntax. If <em>comments</em> is <a class="reference internal" href="constants.html#False" title="False"><code class="xref py py-const docutils literal notranslate"><span class="pre">False</span></code></a> (the default), the parsing of comments in the given string will be disabled (setting the <a class="reference internal" href="#shlex.shlex.commenters" title="shlex.shlex.commenters"><code class="xref py py-attr docutils literal notranslate"><span class="pre">commenters</span></code></a> attribute of the <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> instance to the empty string). This function operates in POSIX mode by default, but uses non-POSIX mode if the <em>posix</em> argument is false.</p> <div class="versionadded"> <p><span class="versionmodified">New in version 2.3.</span></p> </div> <div class="versionchanged"> <p><span class="versionmodified">Changed in version 2.6: </span>Added the <em>posix</em> parameter.</p> </div> <div class="admonition note"> <p class="first admonition-title">Note</p> <p class="last">Since the <a class="reference internal" href="#shlex.split" title="shlex.split"><code class="xref py py-func docutils literal notranslate"><span class="pre">split()</span></code></a> function instantiates a <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> instance, passing <code class="docutils literal notranslate"><span class="pre">None</span></code> for <em>s</em> will read the string to split from standard input.</p> </div> </dd></dl> <p>The <a class="reference internal" href="#module-shlex" title="shlex: Simple lexical analysis for Unix shell-like languages."><code class="xref py py-mod docutils literal notranslate"><span class="pre">shlex</span></code></a> module defines the following class:</p> <dl class="class"> <dt id="shlex.shlex"> <em class="property">class </em><code class="descclassname">shlex.</code><code class="descname">shlex</code><span class="sig-paren">(</span><span class="optional">[</span><em>instream</em><span class="optional">[</span>, <em>infile</em><span class="optional">[</span>, <em>posix</em><span class="optional">]</span><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex" title="Permalink to this definition">¶</a></dt> <dd><p>A <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> instance or subclass instance is a lexical analyzer object. The initialization argument, if present, specifies where to read characters from. It must be a file-/stream-like object with <a class="reference internal" href="io.html#io.TextIOBase.read" title="io.TextIOBase.read"><code class="xref py py-meth docutils literal notranslate"><span class="pre">read()</span></code></a> and <a class="reference internal" href="io.html#io.TextIOBase.readline" title="io.TextIOBase.readline"><code class="xref py py-meth docutils literal notranslate"><span class="pre">readline()</span></code></a> methods, or a string (strings are accepted since Python 2.3). If no argument is given, input will be taken from <code class="docutils literal notranslate"><span class="pre">sys.stdin</span></code>. The second optional argument is a filename string, which sets the initial value of the <a class="reference internal" href="#shlex.shlex.infile" title="shlex.shlex.infile"><code class="xref py py-attr docutils literal notranslate"><span class="pre">infile</span></code></a> attribute. If the <em>instream</em> argument is omitted or equal to <code class="docutils literal notranslate"><span class="pre">sys.stdin</span></code>, this second argument defaults to “stdin”. The <em>posix</em> argument was introduced in Python 2.3, and defines the operational mode. When <em>posix</em> is not true (default), the <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> instance will operate in compatibility mode. When operating in POSIX mode, <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> will try to be as close as possible to the POSIX shell parsing rules.</p> </dd></dl> <div class="admonition seealso"> <p class="first admonition-title">See also</p> <dl class="last docutils"> <dt>Module <a class="reference internal" href="configparser.html#module-ConfigParser" title="ConfigParser: Configuration file parser."><code class="xref py py-mod docutils literal notranslate"><span class="pre">ConfigParser</span></code></a></dt> <dd>Parser for configuration files similar to the Windows <code class="file docutils literal notranslate"><span class="pre">.ini</span></code> files.</dd> </dl> </div> <div class="section" id="shlex-objects"> <span id="id1"></span><h2>23.2.1. shlex Objects<a class="headerlink" href="#shlex-objects" title="Permalink to this headline">¶</a></h2> <p>A <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> instance has the following methods:</p> <dl class="method"> <dt id="shlex.shlex.get_token"> <code class="descclassname">shlex.</code><code class="descname">get_token</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex.get_token" title="Permalink to this definition">¶</a></dt> <dd><p>Return a token. If tokens have been stacked using <a class="reference internal" href="#shlex.shlex.push_token" title="shlex.shlex.push_token"><code class="xref py py-meth docutils literal notranslate"><span class="pre">push_token()</span></code></a>, pop a token off the stack. Otherwise, read one from the input stream. If reading encounters an immediate end-of-file, <a class="reference internal" href="#shlex.shlex.eof" title="shlex.shlex.eof"><code class="xref py py-attr docutils literal notranslate"><span class="pre">eof</span></code></a> is returned (the empty string (<code class="docutils literal notranslate"><span class="pre">''</span></code>) in non-POSIX mode, and <code class="docutils literal notranslate"><span class="pre">None</span></code> in POSIX mode).</p> </dd></dl> <dl class="method"> <dt id="shlex.shlex.push_token"> <code class="descclassname">shlex.</code><code class="descname">push_token</code><span class="sig-paren">(</span><em>str</em><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex.push_token" title="Permalink to this definition">¶</a></dt> <dd><p>Push the argument onto the token stack.</p> </dd></dl> <dl class="method"> <dt id="shlex.shlex.read_token"> <code class="descclassname">shlex.</code><code class="descname">read_token</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex.read_token" title="Permalink to this definition">¶</a></dt> <dd><p>Read a raw token. Ignore the pushback stack, and do not interpret source requests. (This is not ordinarily a useful entry point, and is documented here only for the sake of completeness.)</p> </dd></dl> <dl class="method"> <dt id="shlex.shlex.sourcehook"> <code class="descclassname">shlex.</code><code class="descname">sourcehook</code><span class="sig-paren">(</span><em>filename</em><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex.sourcehook" title="Permalink to this definition">¶</a></dt> <dd><p>When <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> detects a source request (see <a class="reference internal" href="#shlex.shlex.source" title="shlex.shlex.source"><code class="xref py py-attr docutils literal notranslate"><span class="pre">source</span></code></a> below) this method is given the following token as argument, and expected to return a tuple consisting of a filename and an open file-like object.</p> <p>Normally, this method first strips any quotes off the argument. If the result is an absolute pathname, or there was no previous source request in effect, or the previous source was a stream (such as <code class="docutils literal notranslate"><span class="pre">sys.stdin</span></code>), the result is left alone. Otherwise, if the result is a relative pathname, the directory part of the name of the file immediately before it on the source inclusion stack is prepended (this behavior is like the way the C preprocessor handles <code class="docutils literal notranslate"><span class="pre">#include</span> <span class="pre">"file.h"</span></code>).</p> <p>The result of the manipulations is treated as a filename, and returned as the first component of the tuple, with <a class="reference internal" href="functions.html#open" title="open"><code class="xref py py-func docutils literal notranslate"><span class="pre">open()</span></code></a> called on it to yield the second component. (Note: this is the reverse of the order of arguments in instance initialization!)</p> <p>This hook is exposed so that you can use it to implement directory search paths, addition of file extensions, and other namespace hacks. There is no corresponding ‘close’ hook, but a shlex instance will call the <a class="reference internal" href="io.html#io.IOBase.close" title="io.IOBase.close"><code class="xref py py-meth docutils literal notranslate"><span class="pre">close()</span></code></a> method of the sourced input stream when it returns EOF.</p> <p>For more explicit control of source stacking, use the <a class="reference internal" href="#shlex.shlex.push_source" title="shlex.shlex.push_source"><code class="xref py py-meth docutils literal notranslate"><span class="pre">push_source()</span></code></a> and <a class="reference internal" href="#shlex.shlex.pop_source" title="shlex.shlex.pop_source"><code class="xref py py-meth docutils literal notranslate"><span class="pre">pop_source()</span></code></a> methods.</p> </dd></dl> <dl class="method"> <dt id="shlex.shlex.push_source"> <code class="descclassname">shlex.</code><code class="descname">push_source</code><span class="sig-paren">(</span><em>stream</em><span class="optional">[</span>, <em>filename</em><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex.push_source" title="Permalink to this definition">¶</a></dt> <dd><p>Push an input source stream onto the input stack. If the filename argument is specified it will later be available for use in error messages. This is the same method used internally by the <a class="reference internal" href="#shlex.shlex.sourcehook" title="shlex.shlex.sourcehook"><code class="xref py py-meth docutils literal notranslate"><span class="pre">sourcehook()</span></code></a> method.</p> <div class="versionadded"> <p><span class="versionmodified">New in version 2.1.</span></p> </div> </dd></dl> <dl class="method"> <dt id="shlex.shlex.pop_source"> <code class="descclassname">shlex.</code><code class="descname">pop_source</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex.pop_source" title="Permalink to this definition">¶</a></dt> <dd><p>Pop the last-pushed input source from the input stack. This is the same method used internally when the lexer reaches EOF on a stacked input stream.</p> <div class="versionadded"> <p><span class="versionmodified">New in version 2.1.</span></p> </div> </dd></dl> <dl class="method"> <dt id="shlex.shlex.error_leader"> <code class="descclassname">shlex.</code><code class="descname">error_leader</code><span class="sig-paren">(</span><span class="optional">[</span><em>file</em><span class="optional">[</span>, <em>line</em><span class="optional">]</span><span class="optional">]</span><span class="sig-paren">)</span><a class="headerlink" href="#shlex.shlex.error_leader" title="Permalink to this definition">¶</a></dt> <dd><p>This method generates an error message leader in the format of a Unix C compiler error label; the format is <code class="docutils literal notranslate"><span class="pre">'"%s",</span> <span class="pre">line</span> <span class="pre">%d:</span> <span class="pre">'</span></code>, where the <code class="docutils literal notranslate"><span class="pre">%s</span></code> is replaced with the name of the current source file and the <code class="docutils literal notranslate"><span class="pre">%d</span></code> with the current input line number (the optional arguments can be used to override these).</p> <p>This convenience is provided to encourage <a class="reference internal" href="#module-shlex" title="shlex: Simple lexical analysis for Unix shell-like languages."><code class="xref py py-mod docutils literal notranslate"><span class="pre">shlex</span></code></a> users to generate error messages in the standard, parseable format understood by Emacs and other Unix tools.</p> </dd></dl> <p>Instances of <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> subclasses have some public instance variables which either control lexical analysis or can be used for debugging:</p> <dl class="attribute"> <dt id="shlex.shlex.commenters"> <code class="descclassname">shlex.</code><code class="descname">commenters</code><a class="headerlink" href="#shlex.shlex.commenters" title="Permalink to this definition">¶</a></dt> <dd><p>The string of characters that are recognized as comment beginners. All characters from the comment beginner to end of line are ignored. Includes just <code class="docutils literal notranslate"><span class="pre">'#'</span></code> by default.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.wordchars"> <code class="descclassname">shlex.</code><code class="descname">wordchars</code><a class="headerlink" href="#shlex.shlex.wordchars" title="Permalink to this definition">¶</a></dt> <dd><p>The string of characters that will accumulate into multi-character tokens. By default, includes all ASCII alphanumerics and underscore.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.whitespace"> <code class="descclassname">shlex.</code><code class="descname">whitespace</code><a class="headerlink" href="#shlex.shlex.whitespace" title="Permalink to this definition">¶</a></dt> <dd><p>Characters that will be considered whitespace and skipped. Whitespace bounds tokens. By default, includes space, tab, linefeed and carriage-return.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.escape"> <code class="descclassname">shlex.</code><code class="descname">escape</code><a class="headerlink" href="#shlex.shlex.escape" title="Permalink to this definition">¶</a></dt> <dd><p>Characters that will be considered as escape. This will be only used in POSIX mode, and includes just <code class="docutils literal notranslate"><span class="pre">'\'</span></code> by default.</p> <div class="versionadded"> <p><span class="versionmodified">New in version 2.3.</span></p> </div> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.quotes"> <code class="descclassname">shlex.</code><code class="descname">quotes</code><a class="headerlink" href="#shlex.shlex.quotes" title="Permalink to this definition">¶</a></dt> <dd><p>Characters that will be considered string quotes. The token accumulates until the same quote is encountered again (thus, different quote types protect each other as in the shell.) By default, includes ASCII single and double quotes.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.escapedquotes"> <code class="descclassname">shlex.</code><code class="descname">escapedquotes</code><a class="headerlink" href="#shlex.shlex.escapedquotes" title="Permalink to this definition">¶</a></dt> <dd><p>Characters in <a class="reference internal" href="#shlex.shlex.quotes" title="shlex.shlex.quotes"><code class="xref py py-attr docutils literal notranslate"><span class="pre">quotes</span></code></a> that will interpret escape characters defined in <a class="reference internal" href="#shlex.shlex.escape" title="shlex.shlex.escape"><code class="xref py py-attr docutils literal notranslate"><span class="pre">escape</span></code></a>. This is only used in POSIX mode, and includes just <code class="docutils literal notranslate"><span class="pre">'"'</span></code> by default.</p> <div class="versionadded"> <p><span class="versionmodified">New in version 2.3.</span></p> </div> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.whitespace_split"> <code class="descclassname">shlex.</code><code class="descname">whitespace_split</code><a class="headerlink" href="#shlex.shlex.whitespace_split" title="Permalink to this definition">¶</a></dt> <dd><p>If <code class="docutils literal notranslate"><span class="pre">True</span></code>, tokens will only be split in whitespaces. This is useful, for example, for parsing command lines with <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a>, getting tokens in a similar way to shell arguments.</p> <div class="versionadded"> <p><span class="versionmodified">New in version 2.3.</span></p> </div> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.infile"> <code class="descclassname">shlex.</code><code class="descname">infile</code><a class="headerlink" href="#shlex.shlex.infile" title="Permalink to this definition">¶</a></dt> <dd><p>The name of the current input file, as initially set at class instantiation time or stacked by later source requests. It may be useful to examine this when constructing error messages.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.instream"> <code class="descclassname">shlex.</code><code class="descname">instream</code><a class="headerlink" href="#shlex.shlex.instream" title="Permalink to this definition">¶</a></dt> <dd><p>The input stream from which this <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> instance is reading characters.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.source"> <code class="descclassname">shlex.</code><code class="descname">source</code><a class="headerlink" href="#shlex.shlex.source" title="Permalink to this definition">¶</a></dt> <dd><p>This attribute is <code class="docutils literal notranslate"><span class="pre">None</span></code> by default. If you assign a string to it, that string will be recognized as a lexical-level inclusion request similar to the <code class="docutils literal notranslate"><span class="pre">source</span></code> keyword in various shells. That is, the immediately following token will be opened as a filename and input will be taken from that stream until EOF, at which point the <a class="reference internal" href="io.html#io.IOBase.close" title="io.IOBase.close"><code class="xref py py-meth docutils literal notranslate"><span class="pre">close()</span></code></a> method of that stream will be called and the input source will again become the original input stream. Source requests may be stacked any number of levels deep.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.debug"> <code class="descclassname">shlex.</code><code class="descname">debug</code><a class="headerlink" href="#shlex.shlex.debug" title="Permalink to this definition">¶</a></dt> <dd><p>If this attribute is numeric and <code class="docutils literal notranslate"><span class="pre">1</span></code> or more, a <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> instance will print verbose progress output on its behavior. If you need to use this, you can read the module source code to learn the details.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.lineno"> <code class="descclassname">shlex.</code><code class="descname">lineno</code><a class="headerlink" href="#shlex.shlex.lineno" title="Permalink to this definition">¶</a></dt> <dd><p>Source line number (count of newlines seen so far plus one).</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.token"> <code class="descclassname">shlex.</code><code class="descname">token</code><a class="headerlink" href="#shlex.shlex.token" title="Permalink to this definition">¶</a></dt> <dd><p>The token buffer. It may be useful to examine this when catching exceptions.</p> </dd></dl> <dl class="attribute"> <dt id="shlex.shlex.eof"> <code class="descclassname">shlex.</code><code class="descname">eof</code><a class="headerlink" href="#shlex.shlex.eof" title="Permalink to this definition">¶</a></dt> <dd><p>Token used to determine end of file. This will be set to the empty string (<code class="docutils literal notranslate"><span class="pre">''</span></code>), in non-POSIX mode, and to <code class="docutils literal notranslate"><span class="pre">None</span></code> in POSIX mode.</p> <div class="versionadded"> <p><span class="versionmodified">New in version 2.3.</span></p> </div> </dd></dl> </div> <div class="section" id="parsing-rules"> <span id="shlex-parsing-rules"></span><h2>23.2.2. Parsing Rules<a class="headerlink" href="#parsing-rules" title="Permalink to this headline">¶</a></h2> <p>When operating in non-POSIX mode, <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> will try to obey to the following rules.</p> <ul class="simple"> <li>Quote characters are not recognized within words (<code class="docutils literal notranslate"><span class="pre">Do"Not"Separate</span></code> is parsed as the single word <code class="docutils literal notranslate"><span class="pre">Do"Not"Separate</span></code>);</li> <li>Escape characters are not recognized;</li> <li>Enclosing characters in quotes preserve the literal value of all characters within the quotes;</li> <li>Closing quotes separate words (<code class="docutils literal notranslate"><span class="pre">"Do"Separate</span></code> is parsed as <code class="docutils literal notranslate"><span class="pre">"Do"</span></code> and <code class="docutils literal notranslate"><span class="pre">Separate</span></code>);</li> <li>If <a class="reference internal" href="#shlex.shlex.whitespace_split" title="shlex.shlex.whitespace_split"><code class="xref py py-attr docutils literal notranslate"><span class="pre">whitespace_split</span></code></a> is <code class="docutils literal notranslate"><span class="pre">False</span></code>, any character not declared to be a word character, whitespace, or a quote will be returned as a single-character token. If it is <code class="docutils literal notranslate"><span class="pre">True</span></code>, <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> will only split words in whitespaces;</li> <li>EOF is signaled with an empty string (<code class="docutils literal notranslate"><span class="pre">''</span></code>);</li> <li>It’s not possible to parse empty strings, even if quoted.</li> </ul> <p>When operating in POSIX mode, <a class="reference internal" href="#shlex.shlex" title="shlex.shlex"><code class="xref py py-class docutils literal notranslate"><span class="pre">shlex</span></code></a> will try to obey to the following parsing rules.</p> <ul class="simple"> <li>Quotes are stripped out, and do not separate words (<code class="docutils literal notranslate"><span class="pre">"Do"Not"Separate"</span></code> is parsed as the single word <code class="docutils literal notranslate"><span class="pre">DoNotSeparate</span></code>);</li> <li>Non-quoted escape characters (e.g. <code class="docutils literal notranslate"><span class="pre">'\'</span></code>) preserve the literal value of the next character that follows;</li> <li>Enclosing characters in quotes which are not part of <a class="reference internal" href="#shlex.shlex.escapedquotes" title="shlex.shlex.escapedquotes"><code class="xref py py-attr docutils literal notranslate"><span class="pre">escapedquotes</span></code></a> (e.g. <code class="docutils literal notranslate"><span class="pre">"'"</span></code>) preserve the literal value of all characters within the quotes;</li> <li>Enclosing characters in quotes which are part of <a class="reference internal" href="#shlex.shlex.escapedquotes" title="shlex.shlex.escapedquotes"><code class="xref py py-attr docutils literal notranslate"><span class="pre">escapedquotes</span></code></a> (e.g. <code class="docutils literal notranslate"><span class="pre">'"'</span></code>) preserves the literal value of all characters within the quotes, with the exception of the characters mentioned in <a class="reference internal" href="#shlex.shlex.escape" title="shlex.shlex.escape"><code class="xref py py-attr docutils literal notranslate"><span class="pre">escape</span></code></a>. The escape characters retain its special meaning only when followed by the quote in use, or the escape character itself. Otherwise the escape character will be considered a normal character.</li> <li>EOF is signaled with a <a class="reference internal" href="constants.html#None" title="None"><code class="xref py py-const docutils literal notranslate"><span class="pre">None</span></code></a> value;</li> <li>Quoted empty strings (<code class="docutils literal notranslate"><span class="pre">''</span></code>) are allowed;</li> </ul> </div> </div> </div> </div> </div> <div class="sphinxsidebar" role="navigation" aria-label="main navigation"> <div class="sphinxsidebarwrapper"> <h3><a href="../contents.html">Table Of Contents</a></h3> <ul> <li><a class="reference internal" href="#">23.2. <code class="docutils literal notranslate"><span class="pre">shlex</span></code> — Simple lexical analysis</a><ul> <li><a class="reference internal" href="#shlex-objects">23.2.1. shlex Objects</a></li> <li><a class="reference internal" href="#parsing-rules">23.2.2. Parsing Rules</a></li> </ul> </li> </ul> <h4>Previous topic</h4> <p class="topless"><a href="cmd.html" title="previous chapter">23.1. <code class="docutils literal notranslate"><span class="pre">cmd</span></code> — Support for line-oriented command interpreters</a></p> <h4>Next topic</h4> <p class="topless"><a href="tk.html" title="next chapter">24. Graphical User Interfaces with Tk</a></p> <div role="note" aria-label="source link"> <h3>This Page</h3> <ul class="this-page-menu"> <li><a href="../_sources/library/shlex.rst.txt" rel="nofollow">Show Source</a></li> </ul> </div> <div id="searchbox" style="display: none" role="search"> <h3>Quick search</h3> <div class="searchformwrapper"> <form class="search" action="../search.html" method="get"> <input type="text" name="q" /> <input type="submit" value="Go" /> <input type="hidden" name="check_keywords" value="yes" /> <input type="hidden" name="area" value="default" /> </form> </div> </div> <script type="text/javascript">$('#searchbox').show(0);</script> </div> </div> <div class="clearer"></div> </div> <div class="related" role="navigation" aria-label="related navigation"> <h3>Navigation</h3> <ul> <li class="right" style="margin-right: 10px"> <a href="../genindex.html" title="General Index" >index</a></li> <li class="right" > <a href="../py-modindex.html" title="Python Module Index" >modules</a> |</li> <li class="right" > <a href="tk.html" title="24. Graphical User Interfaces with Tk" >next</a> |</li> <li class="right" > <a href="cmd.html" title="23.1. cmd — Support for line-oriented command interpreters" >previous</a> |</li> <li><img src="../_static/py.png" alt="" style="vertical-align: middle; margin-top: -1px"/></li> <li><a href="https://www.python.org/">Python</a> »</li> <li> <a href="../index.html">Python 2.7.16 documentation</a> » </li> <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> »</li> <li class="nav-item nav-item-2"><a href="frameworks.html" >23. Program Frameworks</a> »</li> </ul> </div> <div class="footer"> © <a href="../copyright.html">Copyright</a> 1990-2019, Python Software Foundation. <br /> The Python Software Foundation is a non-profit corporation. <a href="https://www.python.org/psf/donations/">Please donate.</a> <br /> Last updated on Mar 27, 2019. <a href="../bugs.html">Found a bug</a>? <br /> Created using <a href="http://sphinx.pocoo.org/">Sphinx</a> 1.7.6. </div> </body> </html>