X7ROOT File Manager
Current Path:
/lib64/python2.7
lib64
/
python2.7
/
??
..
??
BaseHTTPServer.py
(22.21 KB)
??
BaseHTTPServer.pyc
(21.21 KB)
??
BaseHTTPServer.pyo
(21.21 KB)
??
Bastion.py
(5.61 KB)
??
Bastion.pyc
(6.5 KB)
??
Bastion.pyo
(6.5 KB)
??
CGIHTTPServer.py
(12.78 KB)
??
CGIHTTPServer.pyc
(10.76 KB)
??
CGIHTTPServer.pyo
(10.76 KB)
??
ConfigParser.py
(27.1 KB)
??
ConfigParser.pyc
(24.62 KB)
??
ConfigParser.pyo
(24.62 KB)
??
Cookie.py
(25.92 KB)
??
Cookie.pyc
(22.13 KB)
??
Cookie.pyo
(22.13 KB)
??
Demo
??
Doc
??
DocXMLRPCServer.py
(10.52 KB)
??
DocXMLRPCServer.pyc
(9.96 KB)
??
DocXMLRPCServer.pyo
(9.85 KB)
??
HTMLParser.py
(16.77 KB)
??
HTMLParser.pyc
(13.41 KB)
??
HTMLParser.pyo
(13.11 KB)
??
MimeWriter.py
(6.33 KB)
??
MimeWriter.pyc
(7.19 KB)
??
MimeWriter.pyo
(7.19 KB)
??
Queue.py
(8.38 KB)
??
Queue.pyc
(9.2 KB)
??
Queue.pyo
(9.2 KB)
??
SimpleHTTPServer.py
(7.81 KB)
??
SimpleHTTPServer.pyc
(7.82 KB)
??
SimpleHTTPServer.pyo
(7.82 KB)
??
SimpleXMLRPCServer.py
(25.21 KB)
??
SimpleXMLRPCServer.pyc
(22.33 KB)
??
SimpleXMLRPCServer.pyo
(22.33 KB)
??
SocketServer.py
(23.39 KB)
??
SocketServer.pyc
(23.52 KB)
??
SocketServer.pyo
(23.52 KB)
??
StringIO.py
(10.41 KB)
??
StringIO.pyc
(11.21 KB)
??
StringIO.pyo
(11.21 KB)
??
Tools
??
UserDict.py
(6.89 KB)
??
UserDict.pyc
(9.48 KB)
??
UserDict.pyo
(9.48 KB)
??
UserList.py
(3.56 KB)
??
UserList.pyc
(6.42 KB)
??
UserList.pyo
(6.42 KB)
??
UserString.py
(9.46 KB)
??
UserString.pyc
(14.52 KB)
??
UserString.pyo
(14.52 KB)
??
_LWPCookieJar.py
(6.4 KB)
??
_LWPCookieJar.pyc
(5.31 KB)
??
_LWPCookieJar.pyo
(5.31 KB)
??
_MozillaCookieJar.py
(5.66 KB)
??
_MozillaCookieJar.pyc
(4.36 KB)
??
_MozillaCookieJar.pyo
(4.32 KB)
??
__future__.py
(4.28 KB)
??
__future__.pyc
(4.12 KB)
??
__future__.pyo
(4.12 KB)
??
__phello__.foo.py
(64 B)
??
__phello__.foo.pyc
(125 B)
??
__phello__.foo.pyo
(125 B)
??
_abcoll.py
(18.18 KB)
??
_abcoll.pyc
(25.08 KB)
??
_abcoll.pyo
(25.08 KB)
??
_osx_support.py
(18.65 KB)
??
_osx_support.pyc
(11.48 KB)
??
_osx_support.pyo
(11.48 KB)
??
_pyio.py
(68 KB)
??
_pyio.pyc
(63.18 KB)
??
_pyio.pyo
(63.18 KB)
??
_strptime.py
(20.24 KB)
??
_strptime.pyc
(14.82 KB)
??
_strptime.pyo
(14.82 KB)
??
_sysconfigdata.py
(19.27 KB)
??
_sysconfigdata.pyc
(22.43 KB)
??
_sysconfigdata.pyo
(22.43 KB)
??
_threading_local.py
(7.09 KB)
??
_threading_local.pyc
(6.22 KB)
??
_threading_local.pyo
(6.22 KB)
??
_weakrefset.py
(5.77 KB)
??
_weakrefset.pyc
(9.45 KB)
??
_weakrefset.pyo
(9.45 KB)
??
abc.py
(6.98 KB)
??
abc.pyc
(6 KB)
??
abc.pyo
(5.94 KB)
??
aifc.py
(33.77 KB)
??
aifc.pyc
(29.75 KB)
??
aifc.pyo
(29.75 KB)
??
antigravity.py
(60 B)
??
antigravity.pyc
(203 B)
??
antigravity.pyo
(203 B)
??
anydbm.py
(2.6 KB)
??
anydbm.pyc
(2.73 KB)
??
anydbm.pyo
(2.73 KB)
??
argparse.py
(87.14 KB)
??
argparse.pyc
(62.86 KB)
??
argparse.pyo
(62.7 KB)
??
ast.py
(11.53 KB)
??
ast.pyc
(12.63 KB)
??
ast.pyo
(12.63 KB)
??
asynchat.py
(11.31 KB)
??
asynchat.pyc
(8.6 KB)
??
asynchat.pyo
(8.6 KB)
??
asyncore.py
(20.45 KB)
??
asyncore.pyc
(18.45 KB)
??
asyncore.pyo
(18.45 KB)
??
atexit.py
(1.67 KB)
??
atexit.pyc
(2.15 KB)
??
atexit.pyo
(2.15 KB)
??
audiodev.py
(7.42 KB)
??
audiodev.pyc
(8.27 KB)
??
audiodev.pyo
(8.27 KB)
??
base64.py
(11.53 KB)
??
base64.pyc
(11.03 KB)
??
base64.pyo
(11.03 KB)
??
bdb.py
(21.21 KB)
??
bdb.pyc
(18.65 KB)
??
bdb.pyo
(18.65 KB)
??
binhex.py
(14.35 KB)
??
binhex.pyc
(15.1 KB)
??
binhex.pyo
(15.1 KB)
??
bisect.py
(2.53 KB)
??
bisect.pyc
(3 KB)
??
bisect.pyo
(3 KB)
??
bsddb
??
cProfile.py
(6.42 KB)
??
cProfile.pyc
(6.25 KB)
??
cProfile.pyo
(6.25 KB)
??
calendar.py
(22.84 KB)
??
calendar.pyc
(27.26 KB)
??
calendar.pyo
(27.26 KB)
??
cgi.py
(35.46 KB)
??
cgi.pyc
(32.58 KB)
??
cgi.pyo
(32.58 KB)
??
cgitb.py
(11.89 KB)
??
cgitb.pyc
(11.85 KB)
??
cgitb.pyo
(11.85 KB)
??
chunk.py
(5.29 KB)
??
chunk.pyc
(5.47 KB)
??
chunk.pyo
(5.47 KB)
??
cmd.py
(14.67 KB)
??
cmd.pyc
(13.71 KB)
??
cmd.pyo
(13.71 KB)
??
code.py
(9.95 KB)
??
code.pyc
(10.09 KB)
??
code.pyo
(10.09 KB)
??
codecs.py
(35.3 KB)
??
codecs.pyc
(35.96 KB)
??
codecs.pyo
(35.96 KB)
??
codeop.py
(5.86 KB)
??
codeop.pyc
(6.44 KB)
??
codeop.pyo
(6.44 KB)
??
collections.py
(27.15 KB)
??
collections.pyc
(25.55 KB)
??
collections.pyo
(25.5 KB)
??
colorsys.py
(3.6 KB)
??
colorsys.pyc
(3.9 KB)
??
colorsys.pyo
(3.9 KB)
??
commands.py
(2.49 KB)
??
commands.pyc
(2.41 KB)
??
commands.pyo
(2.41 KB)
??
compileall.py
(7.58 KB)
??
compileall.pyc
(6.85 KB)
??
compileall.pyo
(6.85 KB)
??
compiler
??
config
??
contextlib.py
(4.32 KB)
??
contextlib.pyc
(4.35 KB)
??
contextlib.pyo
(4.35 KB)
??
cookielib.py
(63.95 KB)
??
cookielib.pyc
(53.44 KB)
??
cookielib.pyo
(53.26 KB)
??
copy.py
(11.26 KB)
??
copy.pyc
(11.88 KB)
??
copy.pyo
(11.79 KB)
??
copy_reg.py
(6.81 KB)
??
copy_reg.pyc
(5.05 KB)
??
copy_reg.pyo
(5 KB)
??
crypt.py
(2.24 KB)
??
crypt.pyc
(2.89 KB)
??
crypt.pyo
(2.89 KB)
??
csv.py
(16.32 KB)
??
csv.pyc
(13.19 KB)
??
csv.pyo
(13.19 KB)
??
ctypes
??
curses
??
dbhash.py
(498 B)
??
dbhash.pyc
(718 B)
??
dbhash.pyo
(718 B)
??
decimal.py
(216.73 KB)
??
decimal.pyc
(168.12 KB)
??
decimal.pyo
(168.12 KB)
??
difflib.py
(80.4 KB)
??
difflib.pyc
(60.45 KB)
??
difflib.pyo
(60.4 KB)
??
dircache.py
(1.1 KB)
??
dircache.pyc
(1.54 KB)
??
dircache.pyo
(1.54 KB)
??
dis.py
(6.35 KB)
??
dis.pyc
(6.08 KB)
??
dis.pyo
(6.08 KB)
??
distutils
??
doctest.py
(102.63 KB)
??
doctest.pyc
(81.68 KB)
??
doctest.pyo
(81.4 KB)
??
dumbdbm.py
(8.93 KB)
??
dumbdbm.pyc
(6.59 KB)
??
dumbdbm.pyo
(6.59 KB)
??
dummy_thread.py
(4.31 KB)
??
dummy_thread.pyc
(5.27 KB)
??
dummy_thread.pyo
(5.27 KB)
??
dummy_threading.py
(2.74 KB)
??
dummy_threading.pyc
(1.25 KB)
??
dummy_threading.pyo
(1.25 KB)
??
email
??
encodings
??
ensurepip
??
filecmp.py
(9.36 KB)
??
filecmp.pyc
(9.4 KB)
??
filecmp.pyo
(9.4 KB)
??
fileinput.py
(13.42 KB)
??
fileinput.pyc
(14.16 KB)
??
fileinput.pyo
(14.16 KB)
??
fnmatch.py
(3.24 KB)
??
fnmatch.pyc
(3.53 KB)
??
fnmatch.pyo
(3.53 KB)
??
formatter.py
(14.56 KB)
??
formatter.pyc
(18.73 KB)
??
formatter.pyo
(18.73 KB)
??
fpformat.py
(4.62 KB)
??
fpformat.pyc
(4.59 KB)
??
fpformat.pyo
(4.59 KB)
??
fractions.py
(21.87 KB)
??
fractions.pyc
(19.25 KB)
??
fractions.pyo
(19.25 KB)
??
ftplib.py
(37.65 KB)
??
ftplib.pyc
(34.12 KB)
??
ftplib.pyo
(34.12 KB)
??
functools.py
(4.69 KB)
??
functools.pyc
(6.47 KB)
??
functools.pyo
(6.47 KB)
??
genericpath.py
(3.13 KB)
??
genericpath.pyc
(3.43 KB)
??
genericpath.pyo
(3.43 KB)
??
getopt.py
(7.15 KB)
??
getopt.pyc
(6.5 KB)
??
getopt.pyo
(6.45 KB)
??
getpass.py
(5.43 KB)
??
getpass.pyc
(4.63 KB)
??
getpass.pyo
(4.63 KB)
??
gettext.py
(22.13 KB)
??
gettext.pyc
(17.58 KB)
??
gettext.pyo
(17.58 KB)
??
glob.py
(3.04 KB)
??
glob.pyc
(2.87 KB)
??
glob.pyo
(2.87 KB)
??
gzip.py
(18.58 KB)
??
gzip.pyc
(14.88 KB)
??
gzip.pyo
(14.88 KB)
??
hashlib.py
(7.66 KB)
??
hashlib.pyc
(6.76 KB)
??
hashlib.pyo
(6.76 KB)
??
heapq.py
(17.87 KB)
??
heapq.pyc
(14.22 KB)
??
heapq.pyo
(14.22 KB)
??
hmac.py
(4.48 KB)
??
hmac.pyc
(4.44 KB)
??
hmac.pyo
(4.44 KB)
??
hotshot
??
htmlentitydefs.py
(17.63 KB)
??
htmlentitydefs.pyc
(6.22 KB)
??
htmlentitydefs.pyo
(6.22 KB)
??
htmllib.py
(12.57 KB)
??
htmllib.pyc
(19.83 KB)
??
htmllib.pyo
(19.83 KB)
??
httplib.py
(52.06 KB)
??
httplib.pyc
(37.82 KB)
??
httplib.pyo
(37.64 KB)
??
idlelib
??
ihooks.py
(18.54 KB)
??
ihooks.pyc
(20.87 KB)
??
ihooks.pyo
(20.87 KB)
??
imaplib.py
(47.23 KB)
??
imaplib.pyc
(43.96 KB)
??
imaplib.pyo
(41.32 KB)
??
imghdr.py
(3.46 KB)
??
imghdr.pyc
(4.72 KB)
??
imghdr.pyo
(4.72 KB)
??
importlib
??
imputil.py
(25.16 KB)
??
imputil.pyc
(15.26 KB)
??
imputil.pyo
(15.08 KB)
??
inspect.py
(42 KB)
??
inspect.pyc
(39.29 KB)
??
inspect.pyo
(39.29 KB)
??
io.py
(3.24 KB)
??
io.pyc
(3.5 KB)
??
io.pyo
(3.5 KB)
??
json
??
keyword.py
(1.95 KB)
??
keyword.pyc
(2.06 KB)
??
keyword.pyo
(2.06 KB)
??
lib-dynload
??
lib-tk
??
lib2to3
??
linecache.py
(3.93 KB)
??
linecache.pyc
(3.2 KB)
??
linecache.pyo
(3.2 KB)
??
locale.py
(100.42 KB)
??
locale.pyc
(55.28 KB)
??
locale.pyo
(55.28 KB)
??
logging
??
macpath.py
(6.14 KB)
??
macpath.pyc
(7.5 KB)
??
macpath.pyo
(7.5 KB)
??
macurl2path.py
(2.67 KB)
??
macurl2path.pyc
(2.19 KB)
??
macurl2path.pyo
(2.19 KB)
??
mailbox.py
(79.34 KB)
??
mailbox.pyc
(74.92 KB)
??
mailbox.pyo
(74.87 KB)
??
mailcap.py
(8.21 KB)
??
mailcap.pyc
(7.77 KB)
??
mailcap.pyo
(7.77 KB)
??
markupbase.py
(14.3 KB)
??
markupbase.pyc
(9.05 KB)
??
markupbase.pyo
(8.86 KB)
??
md5.py
(358 B)
??
md5.pyc
(378 B)
??
md5.pyo
(378 B)
??
mhlib.py
(32.65 KB)
??
mhlib.pyc
(32.99 KB)
??
mhlib.pyo
(32.99 KB)
??
mimetools.py
(7 KB)
??
mimetools.pyc
(8.01 KB)
??
mimetools.pyo
(8.01 KB)
??
mimetypes.py
(20.54 KB)
??
mimetypes.pyc
(18.06 KB)
??
mimetypes.pyo
(18.06 KB)
??
mimify.py
(14.67 KB)
??
mimify.pyc
(11.72 KB)
??
mimify.pyo
(11.72 KB)
??
modulefinder.py
(23.89 KB)
??
modulefinder.pyc
(18.68 KB)
??
modulefinder.pyo
(18.6 KB)
??
multifile.py
(4.71 KB)
??
multifile.pyc
(5.29 KB)
??
multifile.pyo
(5.25 KB)
??
multiprocessing
??
mutex.py
(1.83 KB)
??
mutex.pyc
(2.46 KB)
??
mutex.pyo
(2.46 KB)
??
netrc.py
(5.75 KB)
??
netrc.pyc
(4.6 KB)
??
netrc.pyo
(4.6 KB)
??
new.py
(610 B)
??
new.pyc
(862 B)
??
new.pyo
(862 B)
??
nntplib.py
(20.97 KB)
??
nntplib.pyc
(20.55 KB)
??
nntplib.pyo
(20.55 KB)
??
ntpath.py
(18.97 KB)
??
ntpath.pyc
(12.82 KB)
??
ntpath.pyo
(12.82 KB)
??
nturl2path.py
(2.36 KB)
??
nturl2path.pyc
(1.77 KB)
??
nturl2path.pyo
(1.77 KB)
??
numbers.py
(10.08 KB)
??
numbers.pyc
(13.68 KB)
??
numbers.pyo
(13.68 KB)
??
opcode.py
(5.35 KB)
??
opcode.pyc
(6 KB)
??
opcode.pyo
(6 KB)
??
optparse.py
(59.77 KB)
??
optparse.pyc
(52.63 KB)
??
optparse.pyo
(52.55 KB)
??
os.py
(25.3 KB)
??
os.pyc
(25.09 KB)
??
os.pyo
(25.09 KB)
??
os2emxpath.py
(4.53 KB)
??
os2emxpath.pyc
(4.42 KB)
??
os2emxpath.pyo
(4.42 KB)
??
pdb.doc
(7.73 KB)
??
pdb.py
(45.02 KB)
??
pdb.pyc
(42.65 KB)
??
pdb.pyo
(42.65 KB)
??
pickle.py
(44.42 KB)
??
pickle.pyc
(37.66 KB)
??
pickle.pyo
(37.46 KB)
??
pickletools.py
(72.78 KB)
??
pickletools.pyc
(55.7 KB)
??
pickletools.pyo
(54.85 KB)
??
pipes.py
(9.36 KB)
??
pipes.pyc
(9.09 KB)
??
pipes.pyo
(9.09 KB)
??
pkgutil.py
(19.77 KB)
??
pkgutil.pyc
(18.51 KB)
??
pkgutil.pyo
(18.51 KB)
??
plat-linux2
??
platform.py
(51.56 KB)
??
platform.pyc
(37.08 KB)
??
platform.pyo
(37.08 KB)
??
plistlib.py
(15.44 KB)
??
plistlib.pyc
(19.5 KB)
??
plistlib.pyo
(19.41 KB)
??
popen2.py
(8.22 KB)
??
popen2.pyc
(8.81 KB)
??
popen2.pyo
(8.77 KB)
??
poplib.py
(12.52 KB)
??
poplib.pyc
(13.03 KB)
??
poplib.pyo
(13.03 KB)
??
posixfile.py
(7.82 KB)
??
posixfile.pyc
(7.47 KB)
??
posixfile.pyo
(7.47 KB)
??
posixpath.py
(13.96 KB)
??
posixpath.pyc
(11.19 KB)
??
posixpath.pyo
(11.19 KB)
??
pprint.py
(11.5 KB)
??
pprint.pyc
(9.96 KB)
??
pprint.pyo
(9.78 KB)
??
profile.py
(22.25 KB)
??
profile.pyc
(16.07 KB)
??
profile.pyo
(15.83 KB)
??
pstats.py
(26.09 KB)
??
pstats.pyc
(24.43 KB)
??
pstats.pyo
(24.43 KB)
??
pty.py
(4.94 KB)
??
pty.pyc
(4.85 KB)
??
pty.pyo
(4.85 KB)
??
py_compile.py
(5.8 KB)
??
py_compile.pyc
(6.28 KB)
??
py_compile.pyo
(6.28 KB)
??
pyclbr.py
(13.07 KB)
??
pyclbr.pyc
(9.42 KB)
??
pyclbr.pyo
(9.42 KB)
??
pydoc.py
(93.5 KB)
??
pydoc.pyc
(90.18 KB)
??
pydoc.pyo
(90.12 KB)
??
pydoc_data
??
quopri.py
(6.8 KB)
??
quopri.pyc
(6.42 KB)
??
quopri.pyo
(6.42 KB)
??
random.py
(31.7 KB)
??
random.pyc
(25.1 KB)
??
random.pyo
(25.1 KB)
??
re.py
(13.11 KB)
??
re.pyc
(13.1 KB)
??
re.pyo
(13.1 KB)
??
repr.py
(4.2 KB)
??
repr.pyc
(5.26 KB)
??
repr.pyo
(5.26 KB)
??
rexec.py
(19.68 KB)
??
rexec.pyc
(23.25 KB)
??
rexec.pyo
(23.25 KB)
??
rfc822.py
(32.76 KB)
??
rfc822.pyc
(31.07 KB)
??
rfc822.pyo
(31.07 KB)
??
rlcompleter.py
(5.85 KB)
??
rlcompleter.pyc
(5.94 KB)
??
rlcompleter.pyo
(5.94 KB)
??
robotparser.py
(7.51 KB)
??
robotparser.pyc
(7.82 KB)
??
robotparser.pyo
(7.82 KB)
??
runpy.py
(10.82 KB)
??
runpy.pyc
(8.6 KB)
??
runpy.pyo
(8.6 KB)
??
sched.py
(4.97 KB)
??
sched.pyc
(4.88 KB)
??
sched.pyo
(4.88 KB)
??
sets.py
(18.6 KB)
??
sets.pyc
(16.5 KB)
??
sets.pyo
(16.5 KB)
??
sgmllib.py
(17.46 KB)
??
sgmllib.pyc
(15.07 KB)
??
sgmllib.pyo
(15.07 KB)
??
sha.py
(393 B)
??
sha.pyc
(421 B)
??
sha.pyo
(421 B)
??
shelve.py
(7.99 KB)
??
shelve.pyc
(10.02 KB)
??
shelve.pyo
(10.02 KB)
??
shlex.py
(10.9 KB)
??
shlex.pyc
(7.38 KB)
??
shlex.pyo
(7.38 KB)
??
shutil.py
(19.41 KB)
??
shutil.pyc
(18.81 KB)
??
shutil.pyo
(18.81 KB)
??
site-packages
??
site.py
(20.8 KB)
??
site.pyc
(20.3 KB)
??
site.pyo
(20.3 KB)
??
smtpd.py
(18.11 KB)
??
smtpd.pyc
(15.51 KB)
??
smtpd.pyo
(15.51 KB)
??
smtplib.py
(31.38 KB)
??
smtplib.pyc
(29.59 KB)
??
smtplib.pyo
(29.59 KB)
??
sndhdr.py
(5.83 KB)
??
sndhdr.pyc
(7.19 KB)
??
sndhdr.pyo
(7.19 KB)
??
socket.py
(20.13 KB)
??
socket.pyc
(15.77 KB)
??
socket.pyo
(15.69 KB)
??
sqlite3
??
sre.py
(384 B)
??
sre.pyc
(519 B)
??
sre.pyo
(519 B)
??
sre_compile.py
(19.36 KB)
??
sre_compile.pyc
(12.27 KB)
??
sre_compile.pyo
(12.11 KB)
??
sre_constants.py
(7.03 KB)
??
sre_constants.pyc
(6.05 KB)
??
sre_constants.pyo
(6.05 KB)
??
sre_parse.py
(29.98 KB)
??
sre_parse.pyc
(20.66 KB)
??
sre_parse.pyo
(20.66 KB)
??
ssl.py
(38.39 KB)
??
ssl.pyc
(31.95 KB)
??
ssl.pyo
(31.95 KB)
??
stat.py
(1.8 KB)
??
stat.pyc
(2.69 KB)
??
stat.pyo
(2.69 KB)
??
statvfs.py
(898 B)
??
statvfs.pyc
(620 B)
??
statvfs.pyo
(620 B)
??
string.py
(21.04 KB)
??
string.pyc
(19.98 KB)
??
string.pyo
(19.98 KB)
??
stringold.py
(12.16 KB)
??
stringold.pyc
(12.25 KB)
??
stringold.pyo
(12.25 KB)
??
stringprep.py
(13.21 KB)
??
stringprep.pyc
(14.15 KB)
??
stringprep.pyo
(14.08 KB)
??
struct.py
(82 B)
??
struct.pyc
(239 B)
??
struct.pyo
(239 B)
??
subprocess.py
(49.34 KB)
??
subprocess.pyc
(31.64 KB)
??
subprocess.pyo
(31.64 KB)
??
sunau.py
(16.82 KB)
??
sunau.pyc
(17.96 KB)
??
sunau.pyo
(17.96 KB)
??
sunaudio.py
(1.37 KB)
??
sunaudio.pyc
(1.94 KB)
??
sunaudio.pyo
(1.94 KB)
??
symbol.py
(2.01 KB)
??
symbol.pyc
(2.96 KB)
??
symbol.pyo
(2.96 KB)
??
symtable.py
(7.26 KB)
??
symtable.pyc
(11.51 KB)
??
symtable.pyo
(11.38 KB)
??
sysconfig.py
(22.32 KB)
??
sysconfig.pyc
(17.4 KB)
??
sysconfig.pyo
(17.4 KB)
??
tabnanny.py
(11.07 KB)
??
tabnanny.pyc
(8.05 KB)
??
tabnanny.pyo
(8.05 KB)
??
tarfile.py
(88.53 KB)
??
tarfile.pyc
(74.41 KB)
??
tarfile.pyo
(74.41 KB)
??
telnetlib.py
(26.4 KB)
??
telnetlib.pyc
(22.61 KB)
??
telnetlib.pyo
(22.61 KB)
??
tempfile.py
(19.09 KB)
??
tempfile.pyc
(19.87 KB)
??
tempfile.pyo
(19.87 KB)
??
test
??
textwrap.py
(16.88 KB)
??
textwrap.pyc
(11.81 KB)
??
textwrap.pyo
(11.72 KB)
??
this.py
(1002 B)
??
this.pyc
(1.19 KB)
??
this.pyo
(1.19 KB)
??
threading.py
(46.27 KB)
??
threading.pyc
(41.72 KB)
??
threading.pyo
(39.6 KB)
??
timeit.py
(12.49 KB)
??
timeit.pyc
(11.9 KB)
??
timeit.pyo
(11.9 KB)
??
toaiff.py
(3.07 KB)
??
toaiff.pyc
(3.03 KB)
??
toaiff.pyo
(3.03 KB)
??
token.py
(2.85 KB)
??
token.pyc
(3.73 KB)
??
token.pyo
(3.73 KB)
??
tokenize.py
(17.07 KB)
??
tokenize.pyc
(14.17 KB)
??
tokenize.pyo
(14.11 KB)
??
trace.py
(29.19 KB)
??
trace.pyc
(22.26 KB)
??
trace.pyo
(22.2 KB)
??
traceback.py
(11.02 KB)
??
traceback.pyc
(11.41 KB)
??
traceback.pyo
(11.41 KB)
??
tty.py
(879 B)
??
tty.pyc
(1.29 KB)
??
tty.pyo
(1.29 KB)
??
types.py
(2.04 KB)
??
types.pyc
(2.66 KB)
??
types.pyo
(2.66 KB)
??
unittest
??
urllib.py
(58.82 KB)
??
urllib.pyc
(50.04 KB)
??
urllib.pyo
(49.95 KB)
??
urllib2.py
(51.31 KB)
??
urllib2.pyc
(46.19 KB)
??
urllib2.pyo
(46.1 KB)
??
urlparse.py
(19.98 KB)
??
urlparse.pyc
(17.59 KB)
??
urlparse.pyo
(17.59 KB)
??
user.py
(1.59 KB)
??
user.pyc
(1.68 KB)
??
user.pyo
(1.68 KB)
??
uu.py
(6.54 KB)
??
uu.pyc
(4.29 KB)
??
uu.pyo
(4.29 KB)
??
uuid.py
(22.98 KB)
??
uuid.pyc
(22.82 KB)
??
uuid.pyo
(22.71 KB)
??
warnings.py
(14.48 KB)
??
warnings.pyc
(13.19 KB)
??
warnings.pyo
(12.42 KB)
??
wave.py
(18.15 KB)
??
wave.pyc
(19.54 KB)
??
wave.pyo
(19.4 KB)
??
weakref.py
(14.48 KB)
??
weakref.pyc
(16.06 KB)
??
weakref.pyo
(16.06 KB)
??
webbrowser.py
(22.19 KB)
??
webbrowser.pyc
(19.29 KB)
??
webbrowser.pyo
(19.24 KB)
??
whichdb.py
(3.3 KB)
??
whichdb.pyc
(2.19 KB)
??
whichdb.pyo
(2.19 KB)
??
wsgiref
??
wsgiref.egg-info
(187 B)
??
xdrlib.py
(5.93 KB)
??
xdrlib.pyc
(9.67 KB)
??
xdrlib.pyo
(9.67 KB)
??
xml
??
xmllib.py
(34.05 KB)
??
xmllib.pyc
(26.22 KB)
??
xmllib.pyo
(26.22 KB)
??
xmlrpclib.py
(50.91 KB)
??
xmlrpclib.pyc
(43.07 KB)
??
xmlrpclib.pyo
(42.89 KB)
??
zipfile.py
(58.08 KB)
??
zipfile.pyc
(41.15 KB)
??
zipfile.pyo
(41.15 KB)
Editing: xmllib.py
"""A parser for XML, using the derived class as static DTD.""" # Author: Sjoerd Mullender. import re import string import warnings warnings.warn("The xmllib module is obsolete. Use xml.sax instead.", DeprecationWarning, 2) del warnings version = '0.3' class Error(RuntimeError): pass # Regular expressions used for parsing _S = '[ \t\r\n]+' # white space _opS = '[ \t\r\n]*' # optional white space _Name = '[a-zA-Z_:][-a-zA-Z0-9._:]*' # valid XML name _QStr = "(?:'[^']*'|\"[^\"]*\")" # quoted XML string illegal = re.compile('[^\t\r\n -\176\240-\377]') # illegal chars in content interesting = re.compile('[]&<]') amp = re.compile('&') ref = re.compile('&(' + _Name + '|#[0-9]+|#x[0-9a-fA-F]+)[^-a-zA-Z0-9._:]') entityref = re.compile('&(?P<name>' + _Name + ')[^-a-zA-Z0-9._:]') charref = re.compile('&#(?P<char>[0-9]+[^0-9]|x[0-9a-fA-F]+[^0-9a-fA-F])') space = re.compile(_S + '$') newline = re.compile('\n') attrfind = re.compile( _S + '(?P<name>' + _Name + ')' '(' + _opS + '=' + _opS + '(?P<value>'+_QStr+'|[-a-zA-Z0-9.:+*%?!\(\)_#=~]+))?') starttagopen = re.compile('<' + _Name) starttagend = re.compile(_opS + '(?P<slash>/?)>') starttagmatch = re.compile('<(?P<tagname>'+_Name+')' '(?P<attrs>(?:'+attrfind.pattern+')*)'+ starttagend.pattern) endtagopen = re.compile('</') endbracket = re.compile(_opS + '>') endbracketfind = re.compile('(?:[^>\'"]|'+_QStr+')*>') tagfind = re.compile(_Name) cdataopen = re.compile(r'<!\[CDATA\[') cdataclose = re.compile(r'\]\]>') # this matches one of the following: # SYSTEM SystemLiteral # PUBLIC PubidLiteral SystemLiteral _SystemLiteral = '(?P<%s>'+_QStr+')' _PublicLiteral = '(?P<%s>"[-\'\(\)+,./:=?;!*#@$_%% \n\ra-zA-Z0-9]*"|' \ "'[-\(\)+,./:=?;!*#@$_%% \n\ra-zA-Z0-9]*')" _ExternalId = '(?:SYSTEM|' \ 'PUBLIC'+_S+_PublicLiteral%'pubid'+ \ ')'+_S+_SystemLiteral%'syslit' doctype = re.compile('<!DOCTYPE'+_S+'(?P<name>'+_Name+')' '(?:'+_S+_ExternalId+')?'+_opS) xmldecl = re.compile('<\?xml'+_S+ 'version'+_opS+'='+_opS+'(?P<version>'+_QStr+')'+ '(?:'+_S+'encoding'+_opS+'='+_opS+ "(?P<encoding>'[A-Za-z][-A-Za-z0-9._]*'|" '"[A-Za-z][-A-Za-z0-9._]*"))?' '(?:'+_S+'standalone'+_opS+'='+_opS+ '(?P<standalone>\'(?:yes|no)\'|"(?:yes|no)"))?'+ _opS+'\?>') procopen = re.compile(r'<\?(?P<proc>' + _Name + ')' + _opS) procclose = re.compile(_opS + r'\?>') commentopen = re.compile('<!--') commentclose = re.compile('-->') doubledash = re.compile('--') attrtrans = string.maketrans(' \r\n\t', ' ') # definitions for XML namespaces _NCName = '[a-zA-Z_][-a-zA-Z0-9._]*' # XML Name, minus the ":" ncname = re.compile(_NCName + '$') qname = re.compile('(?:(?P<prefix>' + _NCName + '):)?' # optional prefix '(?P<local>' + _NCName + ')$') xmlns = re.compile('xmlns(?::(?P<ncname>'+_NCName+'))?$') # XML parser base class -- find tags and call handler functions. # Usage: p = XMLParser(); p.feed(data); ...; p.close(). # The dtd is defined by deriving a class which defines methods with # special names to handle tags: start_foo and end_foo to handle <foo> # and </foo>, respectively. The data between tags is passed to the # parser by calling self.handle_data() with some data as argument (the # data may be split up in arbitrary chunks). class XMLParser: attributes = {} # default, to be overridden elements = {} # default, to be overridden # parsing options, settable using keyword args in __init__ __accept_unquoted_attributes = 0 __accept_missing_endtag_name = 0 __map_case = 0 __accept_utf8 = 0 __translate_attribute_references = 1 # Interface -- initialize and reset this instance def __init__(self, **kw): self.__fixed = 0 if 'accept_unquoted_attributes' in kw: self.__accept_unquoted_attributes = kw['accept_unquoted_attributes'] if 'accept_missing_endtag_name' in kw: self.__accept_missing_endtag_name = kw['accept_missing_endtag_name'] if 'map_case' in kw: self.__map_case = kw['map_case'] if 'accept_utf8' in kw: self.__accept_utf8 = kw['accept_utf8'] if 'translate_attribute_references' in kw: self.__translate_attribute_references = kw['translate_attribute_references'] self.reset() def __fixelements(self): self.__fixed = 1 self.elements = {} self.__fixdict(self.__dict__) self.__fixclass(self.__class__) def __fixclass(self, kl): self.__fixdict(kl.__dict__) for k in kl.__bases__: self.__fixclass(k) def __fixdict(self, dict): for key in dict.keys(): if key[:6] == 'start_': tag = key[6:] start, end = self.elements.get(tag, (None, None)) if start is None: self.elements[tag] = getattr(self, key), end elif key[:4] == 'end_': tag = key[4:] start, end = self.elements.get(tag, (None, None)) if end is None: self.elements[tag] = start, getattr(self, key) # Interface -- reset this instance. Loses all unprocessed data def reset(self): self.rawdata = '' self.stack = [] self.nomoretags = 0 self.literal = 0 self.lineno = 1 self.__at_start = 1 self.__seen_doctype = None self.__seen_starttag = 0 self.__use_namespaces = 0 self.__namespaces = {'xml':None} # xml is implicitly declared # backward compatibility hack: if elements not overridden, # fill it in ourselves if self.elements is XMLParser.elements: self.__fixelements() # For derived classes only -- enter literal mode (CDATA) till EOF def setnomoretags(self): self.nomoretags = self.literal = 1 # For derived classes only -- enter literal mode (CDATA) def setliteral(self, *args): self.literal = 1 # Interface -- feed some data to the parser. Call this as # often as you want, with as little or as much text as you # want (may include '\n'). (This just saves the text, all the # processing is done by goahead().) def feed(self, data): self.rawdata = self.rawdata + data self.goahead(0) # Interface -- handle the remaining data def close(self): self.goahead(1) if self.__fixed: self.__fixed = 0 # remove self.elements so that we don't leak del self.elements # Interface -- translate references def translate_references(self, data, all = 1): if not self.__translate_attribute_references: return data i = 0 while 1: res = amp.search(data, i) if res is None: return data s = res.start(0) res = ref.match(data, s) if res is None: self.syntax_error("bogus `&'") i = s+1 continue i = res.end(0) str = res.group(1) rescan = 0 if str[0] == '#': if str[1] == 'x': str = chr(int(str[2:], 16)) else: str = chr(int(str[1:])) if data[i - 1] != ';': self.syntax_error("`;' missing after char reference") i = i-1 elif all: if str in self.entitydefs: str = self.entitydefs[str] rescan = 1 elif data[i - 1] != ';': self.syntax_error("bogus `&'") i = s + 1 # just past the & continue else: self.syntax_error("reference to unknown entity `&%s;'" % str) str = '&' + str + ';' elif data[i - 1] != ';': self.syntax_error("bogus `&'") i = s + 1 # just past the & continue # when we get here, str contains the translated text and i points # to the end of the string that is to be replaced data = data[:s] + str + data[i:] if rescan: i = s else: i = s + len(str) # Interface - return a dictionary of all namespaces currently valid def getnamespace(self): nsdict = {} for t, d, nst in self.stack: nsdict.update(d) return nsdict # Internal -- handle data as far as reasonable. May leave state # and data to be processed by a subsequent call. If 'end' is # true, force handling all data as if followed by EOF marker. def goahead(self, end): rawdata = self.rawdata i = 0 n = len(rawdata) while i < n: if i > 0: self.__at_start = 0 if self.nomoretags: data = rawdata[i:n] self.handle_data(data) self.lineno = self.lineno + data.count('\n') i = n break res = interesting.search(rawdata, i) if res: j = res.start(0) else: j = n if i < j: data = rawdata[i:j] if self.__at_start and space.match(data) is None: self.syntax_error('illegal data at start of file') self.__at_start = 0 if not self.stack and space.match(data) is None: self.syntax_error('data not in content') if not self.__accept_utf8 and illegal.search(data): self.syntax_error('illegal character in content') self.handle_data(data) self.lineno = self.lineno + data.count('\n') i = j if i == n: break if rawdata[i] == '<': if starttagopen.match(rawdata, i): if self.literal: data = rawdata[i] self.handle_data(data) self.lineno = self.lineno + data.count('\n') i = i+1 continue k = self.parse_starttag(i) if k < 0: break self.__seen_starttag = 1 self.lineno = self.lineno + rawdata[i:k].count('\n') i = k continue if endtagopen.match(rawdata, i): k = self.parse_endtag(i) if k < 0: break self.lineno = self.lineno + rawdata[i:k].count('\n') i = k continue if commentopen.match(rawdata, i): if self.literal: data = rawdata[i] self.handle_data(data) self.lineno = self.lineno + data.count('\n') i = i+1 continue k = self.parse_comment(i) if k < 0: break self.lineno = self.lineno + rawdata[i:k].count('\n') i = k continue if cdataopen.match(rawdata, i): k = self.parse_cdata(i) if k < 0: break self.lineno = self.lineno + rawdata[i:k].count('\n') i = k continue res = xmldecl.match(rawdata, i) if res: if not self.__at_start: self.syntax_error("<?xml?> declaration not at start of document") version, encoding, standalone = res.group('version', 'encoding', 'standalone') if version[1:-1] != '1.0': raise Error('only XML version 1.0 supported') if encoding: encoding = encoding[1:-1] if standalone: standalone = standalone[1:-1] self.handle_xml(encoding, standalone) i = res.end(0) continue res = procopen.match(rawdata, i) if res: k = self.parse_proc(i) if k < 0: break self.lineno = self.lineno + rawdata[i:k].count('\n') i = k continue res = doctype.match(rawdata, i) if res: if self.literal: data = rawdata[i] self.handle_data(data) self.lineno = self.lineno + data.count('\n') i = i+1 continue if self.__seen_doctype: self.syntax_error('multiple DOCTYPE elements') if self.__seen_starttag: self.syntax_error('DOCTYPE not at beginning of document') k = self.parse_doctype(res) if k < 0: break self.__seen_doctype = res.group('name') if self.__map_case: self.__seen_doctype = self.__seen_doctype.lower() self.lineno = self.lineno + rawdata[i:k].count('\n') i = k continue elif rawdata[i] == '&': if self.literal: data = rawdata[i] self.handle_data(data) i = i+1 continue res = charref.match(rawdata, i) if res is not None: i = res.end(0) if rawdata[i-1] != ';': self.syntax_error("`;' missing in charref") i = i-1 if not self.stack: self.syntax_error('data not in content') self.handle_charref(res.group('char')[:-1]) self.lineno = self.lineno + res.group(0).count('\n') continue res = entityref.match(rawdata, i) if res is not None: i = res.end(0) if rawdata[i-1] != ';': self.syntax_error("`;' missing in entityref") i = i-1 name = res.group('name') if self.__map_case: name = name.lower() if name in self.entitydefs: self.rawdata = rawdata = rawdata[:res.start(0)] + self.entitydefs[name] + rawdata[i:] n = len(rawdata) i = res.start(0) else: self.unknown_entityref(name) self.lineno = self.lineno + res.group(0).count('\n') continue elif rawdata[i] == ']': if self.literal: data = rawdata[i] self.handle_data(data) i = i+1 continue if n-i < 3: break if cdataclose.match(rawdata, i): self.syntax_error("bogus `]]>'") self.handle_data(rawdata[i]) i = i+1 continue else: raise Error('neither < nor & ??') # We get here only if incomplete matches but # nothing else break # end while if i > 0: self.__at_start = 0 if end and i < n: data = rawdata[i] self.syntax_error("bogus `%s'" % data) if not self.__accept_utf8 and illegal.search(data): self.syntax_error('illegal character in content') self.handle_data(data) self.lineno = self.lineno + data.count('\n') self.rawdata = rawdata[i+1:] return self.goahead(end) self.rawdata = rawdata[i:] if end: if not self.__seen_starttag: self.syntax_error('no elements in file') if self.stack: self.syntax_error('missing end tags') while self.stack: self.finish_endtag(self.stack[-1][0]) # Internal -- parse comment, return length or -1 if not terminated def parse_comment(self, i): rawdata = self.rawdata if rawdata[i:i+4] != '<!--': raise Error('unexpected call to handle_comment') res = commentclose.search(rawdata, i+4) if res is None: return -1 if doubledash.search(rawdata, i+4, res.start(0)): self.syntax_error("`--' inside comment") if rawdata[res.start(0)-1] == '-': self.syntax_error('comment cannot end in three dashes') if not self.__accept_utf8 and \ illegal.search(rawdata, i+4, res.start(0)): self.syntax_error('illegal character in comment') self.handle_comment(rawdata[i+4: res.start(0)]) return res.end(0) # Internal -- handle DOCTYPE tag, return length or -1 if not terminated def parse_doctype(self, res): rawdata = self.rawdata n = len(rawdata) name = res.group('name') if self.__map_case: name = name.lower() pubid, syslit = res.group('pubid', 'syslit') if pubid is not None: pubid = pubid[1:-1] # remove quotes pubid = ' '.join(pubid.split()) # normalize if syslit is not None: syslit = syslit[1:-1] # remove quotes j = k = res.end(0) if k >= n: return -1 if rawdata[k] == '[': level = 0 k = k+1 dq = sq = 0 while k < n: c = rawdata[k] if not sq and c == '"': dq = not dq elif not dq and c == "'": sq = not sq elif sq or dq: pass elif level <= 0 and c == ']': res = endbracket.match(rawdata, k+1) if res is None: return -1 self.handle_doctype(name, pubid, syslit, rawdata[j+1:k]) return res.end(0) elif c == '<': level = level + 1 elif c == '>': level = level - 1 if level < 0: self.syntax_error("bogus `>' in DOCTYPE") k = k+1 res = endbracketfind.match(rawdata, k) if res is None: return -1 if endbracket.match(rawdata, k) is None: self.syntax_error('garbage in DOCTYPE') self.handle_doctype(name, pubid, syslit, None) return res.end(0) # Internal -- handle CDATA tag, return length or -1 if not terminated def parse_cdata(self, i): rawdata = self.rawdata if rawdata[i:i+9] != '<![CDATA[': raise Error('unexpected call to parse_cdata') res = cdataclose.search(rawdata, i+9) if res is None: return -1 if not self.__accept_utf8 and \ illegal.search(rawdata, i+9, res.start(0)): self.syntax_error('illegal character in CDATA') if not self.stack: self.syntax_error('CDATA not in content') self.handle_cdata(rawdata[i+9:res.start(0)]) return res.end(0) __xml_namespace_attributes = {'ns':None, 'src':None, 'prefix':None} # Internal -- handle a processing instruction tag def parse_proc(self, i): rawdata = self.rawdata end = procclose.search(rawdata, i) if end is None: return -1 j = end.start(0) if not self.__accept_utf8 and illegal.search(rawdata, i+2, j): self.syntax_error('illegal character in processing instruction') res = tagfind.match(rawdata, i+2) if res is None: raise Error('unexpected call to parse_proc') k = res.end(0) name = res.group(0) if self.__map_case: name = name.lower() if name == 'xml:namespace': self.syntax_error('old-fashioned namespace declaration') self.__use_namespaces = -1 # namespace declaration # this must come after the <?xml?> declaration (if any) # and before the <!DOCTYPE> (if any). if self.__seen_doctype or self.__seen_starttag: self.syntax_error('xml:namespace declaration too late in document') attrdict, namespace, k = self.parse_attributes(name, k, j) if namespace: self.syntax_error('namespace declaration inside namespace declaration') for attrname in attrdict.keys(): if not attrname in self.__xml_namespace_attributes: self.syntax_error("unknown attribute `%s' in xml:namespace tag" % attrname) if not 'ns' in attrdict or not 'prefix' in attrdict: self.syntax_error('xml:namespace without required attributes') prefix = attrdict.get('prefix') if ncname.match(prefix) is None: self.syntax_error('xml:namespace illegal prefix value') return end.end(0) if prefix in self.__namespaces: self.syntax_error('xml:namespace prefix not unique') self.__namespaces[prefix] = attrdict['ns'] else: if name.lower() == 'xml': self.syntax_error('illegal processing instruction target name') self.handle_proc(name, rawdata[k:j]) return end.end(0) # Internal -- parse attributes between i and j def parse_attributes(self, tag, i, j): rawdata = self.rawdata attrdict = {} namespace = {} while i < j: res = attrfind.match(rawdata, i) if res is None: break attrname, attrvalue = res.group('name', 'value') if self.__map_case: attrname = attrname.lower() i = res.end(0) if attrvalue is None: self.syntax_error("no value specified for attribute `%s'" % attrname) attrvalue = attrname elif attrvalue[:1] == "'" == attrvalue[-1:] or \ attrvalue[:1] == '"' == attrvalue[-1:]: attrvalue = attrvalue[1:-1] elif not self.__accept_unquoted_attributes: self.syntax_error("attribute `%s' value not quoted" % attrname) res = xmlns.match(attrname) if res is not None: # namespace declaration ncname = res.group('ncname') namespace[ncname or ''] = attrvalue or None if not self.__use_namespaces: self.__use_namespaces = len(self.stack)+1 continue if '<' in attrvalue: self.syntax_error("`<' illegal in attribute value") if attrname in attrdict: self.syntax_error("attribute `%s' specified twice" % attrname) attrvalue = attrvalue.translate(attrtrans) attrdict[attrname] = self.translate_references(attrvalue) return attrdict, namespace, i # Internal -- handle starttag, return length or -1 if not terminated def parse_starttag(self, i): rawdata = self.rawdata # i points to start of tag end = endbracketfind.match(rawdata, i+1) if end is None: return -1 tag = starttagmatch.match(rawdata, i) if tag is None or tag.end(0) != end.end(0): self.syntax_error('garbage in starttag') return end.end(0) nstag = tagname = tag.group('tagname') if self.__map_case: nstag = tagname = nstag.lower() if not self.__seen_starttag and self.__seen_doctype and \ tagname != self.__seen_doctype: self.syntax_error('starttag does not match DOCTYPE') if self.__seen_starttag and not self.stack: self.syntax_error('multiple elements on top level') k, j = tag.span('attrs') attrdict, nsdict, k = self.parse_attributes(tagname, k, j) self.stack.append((tagname, nsdict, nstag)) if self.__use_namespaces: res = qname.match(tagname) else: res = None if res is not None: prefix, nstag = res.group('prefix', 'local') if prefix is None: prefix = '' ns = None for t, d, nst in self.stack: if prefix in d: ns = d[prefix] if ns is None and prefix != '': ns = self.__namespaces.get(prefix) if ns is not None: nstag = ns + ' ' + nstag elif prefix != '': nstag = prefix + ':' + nstag # undo split self.stack[-1] = tagname, nsdict, nstag # translate namespace of attributes attrnamemap = {} # map from new name to old name (used for error reporting) for key in attrdict.keys(): attrnamemap[key] = key if self.__use_namespaces: nattrdict = {} for key, val in attrdict.items(): okey = key res = qname.match(key) if res is not None: aprefix, key = res.group('prefix', 'local') if self.__map_case: key = key.lower() if aprefix is not None: ans = None for t, d, nst in self.stack: if aprefix in d: ans = d[aprefix] if ans is None: ans = self.__namespaces.get(aprefix) if ans is not None: key = ans + ' ' + key else: key = aprefix + ':' + key nattrdict[key] = val attrnamemap[key] = okey attrdict = nattrdict attributes = self.attributes.get(nstag) if attributes is not None: for key in attrdict.keys(): if not key in attributes: self.syntax_error("unknown attribute `%s' in tag `%s'" % (attrnamemap[key], tagname)) for key, val in attributes.items(): if val is not None and not key in attrdict: attrdict[key] = val method = self.elements.get(nstag, (None, None))[0] self.finish_starttag(nstag, attrdict, method) if tag.group('slash') == '/': self.finish_endtag(tagname) return tag.end(0) # Internal -- parse endtag def parse_endtag(self, i): rawdata = self.rawdata end = endbracketfind.match(rawdata, i+1) if end is None: return -1 res = tagfind.match(rawdata, i+2) if res is None: if self.literal: self.handle_data(rawdata[i]) return i+1 if not self.__accept_missing_endtag_name: self.syntax_error('no name specified in end tag') tag = self.stack[-1][0] k = i+2 else: tag = res.group(0) if self.__map_case: tag = tag.lower() if self.literal: if not self.stack or tag != self.stack[-1][0]: self.handle_data(rawdata[i]) return i+1 k = res.end(0) if endbracket.match(rawdata, k) is None: self.syntax_error('garbage in end tag') self.finish_endtag(tag) return end.end(0) # Internal -- finish processing of start tag def finish_starttag(self, tagname, attrdict, method): if method is not None: self.handle_starttag(tagname, method, attrdict) else: self.unknown_starttag(tagname, attrdict) # Internal -- finish processing of end tag def finish_endtag(self, tag): self.literal = 0 if not tag: self.syntax_error('name-less end tag') found = len(self.stack) - 1 if found < 0: self.unknown_endtag(tag) return else: found = -1 for i in range(len(self.stack)): if tag == self.stack[i][0]: found = i if found == -1: self.syntax_error('unopened end tag') return while len(self.stack) > found: if found < len(self.stack) - 1: self.syntax_error('missing close tag for %s' % self.stack[-1][2]) nstag = self.stack[-1][2] method = self.elements.get(nstag, (None, None))[1] if method is not None: self.handle_endtag(nstag, method) else: self.unknown_endtag(nstag) if self.__use_namespaces == len(self.stack): self.__use_namespaces = 0 del self.stack[-1] # Overridable -- handle xml processing instruction def handle_xml(self, encoding, standalone): pass # Overridable -- handle DOCTYPE def handle_doctype(self, tag, pubid, syslit, data): pass # Overridable -- handle start tag def handle_starttag(self, tag, method, attrs): method(attrs) # Overridable -- handle end tag def handle_endtag(self, tag, method): method() # Example -- handle character reference, no need to override def handle_charref(self, name): try: if name[0] == 'x': n = int(name[1:], 16) else: n = int(name) except ValueError: self.unknown_charref(name) return if not 0 <= n <= 255: self.unknown_charref(name) return self.handle_data(chr(n)) # Definition of entities -- derived classes may override entitydefs = {'lt': '<', # must use charref 'gt': '>', 'amp': '&', # must use charref 'quot': '"', 'apos': ''', } # Example -- handle data, should be overridden def handle_data(self, data): pass # Example -- handle cdata, could be overridden def handle_cdata(self, data): pass # Example -- handle comment, could be overridden def handle_comment(self, data): pass # Example -- handle processing instructions, could be overridden def handle_proc(self, name, data): pass # Example -- handle relatively harmless syntax errors, could be overridden def syntax_error(self, message): raise Error('Syntax error at line %d: %s' % (self.lineno, message)) # To be overridden -- handlers for unknown objects def unknown_starttag(self, tag, attrs): pass def unknown_endtag(self, tag): pass def unknown_charref(self, ref): pass def unknown_entityref(self, name): self.syntax_error("reference to unknown entity `&%s;'" % name) class TestXMLParser(XMLParser): def __init__(self, **kw): self.testdata = "" XMLParser.__init__(self, **kw) def handle_xml(self, encoding, standalone): self.flush() print 'xml: encoding =',encoding,'standalone =',standalone def handle_doctype(self, tag, pubid, syslit, data): self.flush() print 'DOCTYPE:',tag, repr(data) def handle_data(self, data): self.testdata = self.testdata + data if len(repr(self.testdata)) >= 70: self.flush() def flush(self): data = self.testdata if data: self.testdata = "" print 'data:', repr(data) def handle_cdata(self, data): self.flush() print 'cdata:', repr(data) def handle_proc(self, name, data): self.flush() print 'processing:',name,repr(data) def handle_comment(self, data): self.flush() r = repr(data) if len(r) > 68: r = r[:32] + '...' + r[-32:] print 'comment:', r def syntax_error(self, message): print 'error at line %d:' % self.lineno, message def unknown_starttag(self, tag, attrs): self.flush() if not attrs: print 'start tag: <' + tag + '>' else: print 'start tag: <' + tag, for name, value in attrs.items(): print name + '=' + '"' + value + '"', print '>' def unknown_endtag(self, tag): self.flush() print 'end tag: </' + tag + '>' def unknown_entityref(self, ref): self.flush() print '*** unknown entity ref: &' + ref + ';' def unknown_charref(self, ref): self.flush() print '*** unknown char ref: &#' + ref + ';' def close(self): XMLParser.close(self) self.flush() def test(args = None): import sys, getopt from time import time if not args: args = sys.argv[1:] opts, args = getopt.getopt(args, 'st') klass = TestXMLParser do_time = 0 for o, a in opts: if o == '-s': klass = XMLParser elif o == '-t': do_time = 1 if args: file = args[0] else: file = 'test.xml' if file == '-': f = sys.stdin else: try: f = open(file, 'r') except IOError, msg: print file, ":", msg sys.exit(1) data = f.read() if f is not sys.stdin: f.close() x = klass() t0 = time() try: if do_time: x.feed(data) x.close() else: for c in data: x.feed(c) x.close() except Error, msg: t1 = time() print msg if do_time: print 'total time: %g' % (t1-t0) sys.exit(1) t1 = time() if do_time: print 'total time: %g' % (t1-t0) if __name__ == '__main__': test()
Upload File
Create Folder