Linux premium180.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
LiteSpeed
: 162.0.209.168 | : 216.73.216.187
Cant Read [ /etc/named.conf ]
8.3.30
nortrmdp
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
/
opt /
alt /
python27 /
lib64 /
python2.7 /
[ HOME SHELL ]
Name
Size
Permission
Action
bsddb
[ DIR ]
drwxr-xr-x
compiler
[ DIR ]
drwxr-xr-x
config
[ DIR ]
drwxr-xr-x
ctypes
[ DIR ]
drwxr-xr-x
curses
[ DIR ]
drwxr-xr-x
distutils
[ DIR ]
drwxr-xr-x
email
[ DIR ]
drwxr-xr-x
encodings
[ DIR ]
drwxr-xr-x
ensurepip
[ DIR ]
drwxr-xr-x
hotshot
[ DIR ]
drwxr-xr-x
idlelib
[ DIR ]
drwxr-xr-x
importlib
[ DIR ]
drwxr-xr-x
json
[ DIR ]
drwxr-xr-x
lib-dynload
[ DIR ]
drwxr-xr-x
lib2to3
[ DIR ]
drwxr-xr-x
logging
[ DIR ]
drwxr-xr-x
multiprocessing
[ DIR ]
drwxr-xr-x
plat-linux2
[ DIR ]
drwxr-xr-x
pydoc_data
[ DIR ]
drwxr-xr-x
site-packages
[ DIR ]
drwxr-xr-x
sqlite3
[ DIR ]
drwxr-xr-x
test
[ DIR ]
drwxr-xr-x
unittest
[ DIR ]
drwxr-xr-x
wsgiref
[ DIR ]
drwxr-xr-x
xml
[ DIR ]
drwxr-xr-x
BaseHTTPServer.py
22.21
KB
-rw-r--r--
BaseHTTPServer.pyc
21.47
KB
-rw-r--r--
BaseHTTPServer.pyo
21.47
KB
-rw-r--r--
Bastion.py
5.61
KB
-rw-r--r--
Bastion.pyc
6.69
KB
-rw-r--r--
Bastion.pyo
6.69
KB
-rw-r--r--
CGIHTTPServer.py
12.78
KB
-rw-r--r--
CGIHTTPServer.pyc
10.92
KB
-rw-r--r--
CGIHTTPServer.pyo
10.92
KB
-rw-r--r--
ConfigParser.py
27.1
KB
-rw-r--r--
ConfigParser.pyc
25.37
KB
-rw-r--r--
ConfigParser.pyo
25.37
KB
-rw-r--r--
Cookie.py
25.92
KB
-rw-r--r--
Cookie.pyc
22.61
KB
-rw-r--r--
Cookie.pyo
22.61
KB
-rw-r--r--
DocXMLRPCServer.py
10.52
KB
-rw-r--r--
DocXMLRPCServer.pyc
10.2
KB
-rw-r--r--
DocXMLRPCServer.pyo
10.09
KB
-rw-r--r--
HTMLParser.py
16.77
KB
-rw-r--r--
HTMLParser.pyc
13.81
KB
-rw-r--r--
HTMLParser.pyo
13.51
KB
-rw-r--r--
MimeWriter.py
6.33
KB
-rw-r--r--
MimeWriter.pyc
7.31
KB
-rw-r--r--
MimeWriter.pyo
7.31
KB
-rw-r--r--
Queue.py
8.38
KB
-rw-r--r--
Queue.pyc
9.56
KB
-rw-r--r--
Queue.pyo
9.56
KB
-rw-r--r--
SimpleHTTPServer.py
7.81
KB
-rw-r--r--
SimpleHTTPServer.pyc
7.96
KB
-rw-r--r--
SimpleHTTPServer.pyo
7.96
KB
-rw-r--r--
SimpleXMLRPCServer.py
25.21
KB
-rw-r--r--
SimpleXMLRPCServer.pyc
22.78
KB
-rw-r--r--
SimpleXMLRPCServer.pyo
22.78
KB
-rw-r--r--
SocketServer.py
23.39
KB
-rw-r--r--
SocketServer.pyc
24.25
KB
-rw-r--r--
SocketServer.pyo
24.25
KB
-rw-r--r--
StringIO.py
10.41
KB
-rw-r--r--
StringIO.pyc
11.45
KB
-rw-r--r--
StringIO.pyo
11.45
KB
-rw-r--r--
UserDict.py
6.89
KB
-rw-r--r--
UserDict.pyc
10.05
KB
-rw-r--r--
UserDict.pyo
10.05
KB
-rw-r--r--
UserList.py
3.56
KB
-rw-r--r--
UserList.pyc
6.85
KB
-rw-r--r--
UserList.pyo
6.85
KB
-rw-r--r--
UserString.py
9.47
KB
-rwxr-xr-x
UserString.pyc
15.38
KB
-rw-r--r--
UserString.pyo
15.38
KB
-rw-r--r--
_LWPCookieJar.py
6.4
KB
-rw-r--r--
_LWPCookieJar.pyc
5.38
KB
-rw-r--r--
_LWPCookieJar.pyo
5.38
KB
-rw-r--r--
_MozillaCookieJar.py
5.66
KB
-rw-r--r--
_MozillaCookieJar.pyc
4.41
KB
-rw-r--r--
_MozillaCookieJar.pyo
4.37
KB
-rw-r--r--
__future__.py
4.28
KB
-rw-r--r--
__future__.pyc
4.2
KB
-rw-r--r--
__future__.pyo
4.2
KB
-rw-r--r--
__phello__.foo.py
64
B
-rw-r--r--
__phello__.foo.pyc
138
B
-rw-r--r--
__phello__.foo.pyo
138
B
-rw-r--r--
_abcoll.py
18.18
KB
-rw-r--r--
_abcoll.pyc
26.4
KB
-rw-r--r--
_abcoll.pyo
26.4
KB
-rw-r--r--
_osx_support.py
18.65
KB
-rw-r--r--
_osx_support.pyc
11.72
KB
-rw-r--r--
_osx_support.pyo
11.72
KB
-rw-r--r--
_pyio.py
68
KB
-rw-r--r--
_pyio.pyc
65.41
KB
-rw-r--r--
_pyio.pyo
65.41
KB
-rw-r--r--
_strptime.py
20.24
KB
-rw-r--r--
_strptime.pyc
15.07
KB
-rw-r--r--
_strptime.pyo
15.07
KB
-rw-r--r--
_sysconfigdata.py
20.67
KB
-rw-r--r--
_sysconfigdata.pyc
23.71
KB
-rw-r--r--
_sysconfigdata.pyo
23.71
KB
-rw-r--r--
_threading_local.py
7.09
KB
-rw-r--r--
_threading_local.pyc
6.34
KB
-rw-r--r--
_threading_local.pyo
6.34
KB
-rw-r--r--
_weakrefset.py
5.77
KB
-rw-r--r--
_weakrefset.pyc
10.06
KB
-rw-r--r--
_weakrefset.pyo
10.06
KB
-rw-r--r--
abc.py
6.98
KB
-rw-r--r--
abc.pyc
6.14
KB
-rw-r--r--
abc.pyo
6.08
KB
-rw-r--r--
aifc.py
33.77
KB
-rw-r--r--
aifc.pyc
30.67
KB
-rw-r--r--
aifc.pyo
30.67
KB
-rw-r--r--
antigravity.py
60
B
-rw-r--r--
antigravity.pyc
216
B
-rw-r--r--
antigravity.pyo
216
B
-rw-r--r--
anydbm.py
2.6
KB
-rw-r--r--
anydbm.pyc
2.77
KB
-rw-r--r--
anydbm.pyo
2.77
KB
-rw-r--r--
argparse.py
87.14
KB
-rw-r--r--
argparse.pyc
64.83
KB
-rw-r--r--
argparse.pyo
64.67
KB
-rw-r--r--
ast.py
11.53
KB
-rw-r--r--
ast.pyc
12.94
KB
-rw-r--r--
ast.pyo
12.94
KB
-rw-r--r--
asynchat.py
11.31
KB
-rw-r--r--
asynchat.pyc
8.98
KB
-rw-r--r--
asynchat.pyo
8.98
KB
-rw-r--r--
asyncore.py
20.45
KB
-rw-r--r--
asyncore.pyc
19.2
KB
-rw-r--r--
asyncore.pyo
19.2
KB
-rw-r--r--
atexit.py
1.67
KB
-rw-r--r--
atexit.pyc
2.23
KB
-rw-r--r--
atexit.pyo
2.23
KB
-rw-r--r--
audiodev.py
7.42
KB
-rw-r--r--
audiodev.pyc
8.61
KB
-rw-r--r--
audiodev.pyo
8.61
KB
-rw-r--r--
base64.py
11.54
KB
-rwxr-xr-x
base64.pyc
11.26
KB
-rw-r--r--
base64.pyo
11.26
KB
-rw-r--r--
bdb.py
21.21
KB
-rw-r--r--
bdb.pyc
19.43
KB
-rw-r--r--
bdb.pyo
19.43
KB
-rw-r--r--
binhex.py
14.35
KB
-rw-r--r--
binhex.pyc
15.75
KB
-rw-r--r--
binhex.pyo
15.75
KB
-rw-r--r--
bisect.py
2.53
KB
-rw-r--r--
bisect.pyc
3.06
KB
-rw-r--r--
bisect.pyo
3.06
KB
-rw-r--r--
cProfile.py
6.43
KB
-rwxr-xr-x
cProfile.pyc
6.42
KB
-rw-r--r--
cProfile.pyo
6.42
KB
-rw-r--r--
calendar.py
22.84
KB
-rw-r--r--
calendar.pyc
28.26
KB
-rw-r--r--
calendar.pyo
28.26
KB
-rw-r--r--
cgi.py
34.97
KB
-rwxr-xr-x
cgi.pyc
33.24
KB
-rw-r--r--
cgi.pyo
33.24
KB
-rw-r--r--
cgitb.py
11.89
KB
-rw-r--r--
cgitb.pyc
12.08
KB
-rw-r--r--
cgitb.pyo
12.08
KB
-rw-r--r--
chunk.py
5.29
KB
-rw-r--r--
chunk.pyc
5.61
KB
-rw-r--r--
chunk.pyo
5.61
KB
-rw-r--r--
cmd.py
14.67
KB
-rw-r--r--
cmd.pyc
13.98
KB
-rw-r--r--
cmd.pyo
13.98
KB
-rw-r--r--
code.py
9.95
KB
-rw-r--r--
code.pyc
10.29
KB
-rw-r--r--
code.pyo
10.29
KB
-rw-r--r--
codecs.py
35.3
KB
-rw-r--r--
codecs.pyc
37.15
KB
-rw-r--r--
codecs.pyo
37.15
KB
-rw-r--r--
codeop.py
5.86
KB
-rw-r--r--
codeop.pyc
6.57
KB
-rw-r--r--
codeop.pyo
6.57
KB
-rw-r--r--
collections.py
27.15
KB
-rw-r--r--
collections.pyc
26.21
KB
-rw-r--r--
collections.pyo
26.16
KB
-rw-r--r--
colorsys.py
3.6
KB
-rw-r--r--
colorsys.pyc
4
KB
-rw-r--r--
colorsys.pyo
4
KB
-rw-r--r--
commands.py
2.49
KB
-rw-r--r--
commands.pyc
2.49
KB
-rw-r--r--
commands.pyo
2.49
KB
-rw-r--r--
compileall.py
7.58
KB
-rw-r--r--
compileall.pyc
6.93
KB
-rw-r--r--
compileall.pyo
6.93
KB
-rw-r--r--
contextlib.py
4.32
KB
-rw-r--r--
contextlib.pyc
4.5
KB
-rw-r--r--
contextlib.pyo
4.5
KB
-rw-r--r--
cookielib.py
63.95
KB
-rw-r--r--
cookielib.pyc
54.67
KB
-rw-r--r--
cookielib.pyo
54.49
KB
-rw-r--r--
copy.py
11.26
KB
-rw-r--r--
copy.pyc
12.21
KB
-rw-r--r--
copy.pyo
12.13
KB
-rw-r--r--
copy_reg.py
6.81
KB
-rw-r--r--
copy_reg.pyc
5.19
KB
-rw-r--r--
copy_reg.pyo
5.14
KB
-rw-r--r--
crypt.py
2.24
KB
-rw-r--r--
crypt.pyc
2.95
KB
-rw-r--r--
crypt.pyo
2.95
KB
-rw-r--r--
csv.py
16.32
KB
-rw-r--r--
csv.pyc
13.56
KB
-rw-r--r--
csv.pyo
13.56
KB
-rw-r--r--
dbhash.py
498
B
-rw-r--r--
dbhash.pyc
744
B
-rw-r--r--
dbhash.pyo
744
B
-rw-r--r--
decimal.py
216.73
KB
-rw-r--r--
decimal.pyc
171.36
KB
-rw-r--r--
decimal.pyo
171.36
KB
-rw-r--r--
difflib.py
80.4
KB
-rw-r--r--
difflib.pyc
61.13
KB
-rw-r--r--
difflib.pyo
61.08
KB
-rw-r--r--
dircache.py
1.1
KB
-rw-r--r--
dircache.pyc
1.59
KB
-rw-r--r--
dircache.pyo
1.59
KB
-rw-r--r--
dis.py
6.35
KB
-rw-r--r--
dis.pyc
6.18
KB
-rw-r--r--
dis.pyo
6.18
KB
-rw-r--r--
doctest.py
102.63
KB
-rw-r--r--
doctest.pyc
83.21
KB
-rw-r--r--
doctest.pyo
82.93
KB
-rw-r--r--
dumbdbm.py
8.93
KB
-rw-r--r--
dumbdbm.pyc
6.83
KB
-rw-r--r--
dumbdbm.pyo
6.83
KB
-rw-r--r--
dummy_thread.py
4.31
KB
-rw-r--r--
dummy_thread.pyc
5.46
KB
-rw-r--r--
dummy_thread.pyo
5.46
KB
-rw-r--r--
dummy_threading.py
2.74
KB
-rw-r--r--
dummy_threading.pyc
1.27
KB
-rw-r--r--
dummy_threading.pyo
1.27
KB
-rw-r--r--
filecmp.py
9.36
KB
-rw-r--r--
filecmp.pyc
9.65
KB
-rw-r--r--
filecmp.pyo
9.65
KB
-rw-r--r--
fileinput.py
13.42
KB
-rw-r--r--
fileinput.pyc
14.54
KB
-rw-r--r--
fileinput.pyo
14.54
KB
-rw-r--r--
fnmatch.py
3.24
KB
-rw-r--r--
fnmatch.pyc
3.61
KB
-rw-r--r--
fnmatch.pyo
3.61
KB
-rw-r--r--
formatter.py
14.56
KB
-rw-r--r--
formatter.pyc
19.71
KB
-rw-r--r--
formatter.pyo
19.71
KB
-rw-r--r--
fpformat.py
4.62
KB
-rw-r--r--
fpformat.pyc
4.69
KB
-rw-r--r--
fpformat.pyo
4.69
KB
-rw-r--r--
fractions.py
21.87
KB
-rw-r--r--
fractions.pyc
19.74
KB
-rw-r--r--
fractions.pyo
19.74
KB
-rw-r--r--
ftplib.py
37.3
KB
-rw-r--r--
ftplib.pyc
34.82
KB
-rw-r--r--
ftplib.pyo
34.82
KB
-rw-r--r--
functools.py
4.69
KB
-rw-r--r--
functools.pyc
6.85
KB
-rw-r--r--
functools.pyo
6.85
KB
-rw-r--r--
genericpath.py
3.13
KB
-rw-r--r--
genericpath.pyc
3.57
KB
-rw-r--r--
genericpath.pyo
3.57
KB
-rw-r--r--
getopt.py
7.15
KB
-rw-r--r--
getopt.pyc
6.63
KB
-rw-r--r--
getopt.pyo
6.58
KB
-rw-r--r--
getpass.py
5.43
KB
-rw-r--r--
getpass.pyc
4.72
KB
-rw-r--r--
getpass.pyo
4.72
KB
-rw-r--r--
gettext.py
22.13
KB
-rw-r--r--
gettext.pyc
18.17
KB
-rw-r--r--
gettext.pyo
18.17
KB
-rw-r--r--
glob.py
3.04
KB
-rw-r--r--
glob.pyc
2.98
KB
-rw-r--r--
glob.pyo
2.98
KB
-rw-r--r--
gzip.py
18.58
KB
-rw-r--r--
gzip.pyc
15.26
KB
-rw-r--r--
gzip.pyo
15.26
KB
-rw-r--r--
hashlib.py
7.66
KB
-rw-r--r--
hashlib.pyc
6.86
KB
-rw-r--r--
hashlib.pyo
6.86
KB
-rw-r--r--
heapq.py
17.87
KB
-rw-r--r--
heapq.pyc
14.45
KB
-rw-r--r--
heapq.pyo
14.45
KB
-rw-r--r--
hmac.py
4.48
KB
-rw-r--r--
hmac.pyc
4.56
KB
-rw-r--r--
hmac.pyo
4.56
KB
-rw-r--r--
htmlentitydefs.py
17.63
KB
-rw-r--r--
htmlentitydefs.pyc
6.23
KB
-rw-r--r--
htmlentitydefs.pyo
6.23
KB
-rw-r--r--
htmllib.py
12.57
KB
-rw-r--r--
htmllib.pyc
20.99
KB
-rw-r--r--
htmllib.pyo
20.99
KB
-rw-r--r--
httplib.py
51.07
KB
-rw-r--r--
httplib.pyc
37.88
KB
-rw-r--r--
httplib.pyo
37.7
KB
-rw-r--r--
ihooks.py
18.54
KB
-rw-r--r--
ihooks.pyc
21.75
KB
-rw-r--r--
ihooks.pyo
21.75
KB
-rw-r--r--
imaplib.py
47.23
KB
-rw-r--r--
imaplib.pyc
45.19
KB
-rw-r--r--
imaplib.pyo
42.49
KB
-rw-r--r--
imghdr.py
3.46
KB
-rw-r--r--
imghdr.pyc
4.93
KB
-rw-r--r--
imghdr.pyo
4.93
KB
-rw-r--r--
imputil.py
25.16
KB
-rw-r--r--
imputil.pyc
15.74
KB
-rw-r--r--
imputil.pyo
15.57
KB
-rw-r--r--
inspect.py
42
KB
-rw-r--r--
inspect.pyc
40.16
KB
-rw-r--r--
inspect.pyo
40.16
KB
-rw-r--r--
io.py
3.24
KB
-rw-r--r--
io.pyc
3.57
KB
-rw-r--r--
io.pyo
3.57
KB
-rw-r--r--
keyword.py
1.96
KB
-rwxr-xr-x
keyword.pyc
2.08
KB
-rw-r--r--
keyword.pyo
2.08
KB
-rw-r--r--
linecache.py
3.93
KB
-rw-r--r--
linecache.pyc
3.27
KB
-rw-r--r--
linecache.pyo
3.27
KB
-rw-r--r--
locale.py
100.42
KB
-rw-r--r--
locale.pyc
55.69
KB
-rw-r--r--
locale.pyo
55.69
KB
-rw-r--r--
macpath.py
6.14
KB
-rw-r--r--
macpath.pyc
7.74
KB
-rw-r--r--
macpath.pyo
7.74
KB
-rw-r--r--
macurl2path.py
2.67
KB
-rw-r--r--
macurl2path.pyc
2.24
KB
-rw-r--r--
macurl2path.pyo
2.24
KB
-rw-r--r--
mailbox.py
79.34
KB
-rw-r--r--
mailbox.pyc
77.7
KB
-rw-r--r--
mailbox.pyo
77.65
KB
-rw-r--r--
mailcap.py
7.25
KB
-rw-r--r--
mailcap.pyc
7.08
KB
-rw-r--r--
mailcap.pyo
7.08
KB
-rw-r--r--
markupbase.py
14.3
KB
-rw-r--r--
markupbase.pyc
9.27
KB
-rw-r--r--
markupbase.pyo
9.07
KB
-rw-r--r--
md5.py
358
B
-rw-r--r--
md5.pyc
391
B
-rw-r--r--
md5.pyo
391
B
-rw-r--r--
mhlib.py
32.65
KB
-rw-r--r--
mhlib.pyc
33.98
KB
-rw-r--r--
mhlib.pyo
33.98
KB
-rw-r--r--
mimetools.py
7
KB
-rw-r--r--
mimetools.pyc
8.26
KB
-rw-r--r--
mimetools.pyo
8.26
KB
-rw-r--r--
mimetypes.py
20.54
KB
-rw-r--r--
mimetypes.pyc
18.3
KB
-rw-r--r--
mimetypes.pyo
18.3
KB
-rw-r--r--
mimify.py
14.68
KB
-rwxr-xr-x
mimify.pyc
11.91
KB
-rw-r--r--
mimify.pyo
11.91
KB
-rw-r--r--
modulefinder.py
23.89
KB
-rw-r--r--
modulefinder.pyc
19.12
KB
-rw-r--r--
modulefinder.pyo
19.04
KB
-rw-r--r--
multifile.py
4.71
KB
-rw-r--r--
multifile.pyc
5.48
KB
-rw-r--r--
multifile.pyo
5.44
KB
-rw-r--r--
mutex.py
1.83
KB
-rw-r--r--
mutex.pyc
2.55
KB
-rw-r--r--
mutex.pyo
2.55
KB
-rw-r--r--
netrc.py
5.75
KB
-rw-r--r--
netrc.pyc
4.72
KB
-rw-r--r--
netrc.pyo
4.72
KB
-rw-r--r--
new.py
610
B
-rw-r--r--
new.pyc
875
B
-rw-r--r--
new.pyo
875
B
-rw-r--r--
nntplib.py
20.97
KB
-rw-r--r--
nntplib.pyc
21.11
KB
-rw-r--r--
nntplib.pyo
21.11
KB
-rw-r--r--
ntpath.py
18.97
KB
-rw-r--r--
ntpath.pyc
13.1
KB
-rw-r--r--
ntpath.pyo
13.1
KB
-rw-r--r--
nturl2path.py
2.36
KB
-rw-r--r--
nturl2path.pyc
1.81
KB
-rw-r--r--
nturl2path.pyo
1.81
KB
-rw-r--r--
numbers.py
10.08
KB
-rw-r--r--
numbers.pyc
14.47
KB
-rw-r--r--
numbers.pyo
14.47
KB
-rw-r--r--
opcode.py
5.35
KB
-rw-r--r--
opcode.pyc
6.06
KB
-rw-r--r--
opcode.pyo
6.06
KB
-rw-r--r--
optparse.py
59.77
KB
-rw-r--r--
optparse.pyc
54.41
KB
-rw-r--r--
optparse.pyo
54.33
KB
-rw-r--r--
os.py
25.3
KB
-rw-r--r--
os.pyc
25.76
KB
-rw-r--r--
os.pyo
25.76
KB
-rw-r--r--
os2emxpath.py
4.53
KB
-rw-r--r--
os2emxpath.pyc
4.53
KB
-rw-r--r--
os2emxpath.pyo
4.53
KB
-rw-r--r--
pdb.doc
7.73
KB
-rw-r--r--
pdb.py
45.03
KB
-rwxr-xr-x
pdb.pyc
44.09
KB
-rw-r--r--
pdb.pyo
44.09
KB
-rw-r--r--
pickle.py
44.42
KB
-rw-r--r--
pickle.pyc
38.98
KB
-rw-r--r--
pickle.pyo
38.79
KB
-rw-r--r--
pickletools.py
72.78
KB
-rw-r--r--
pickletools.pyc
56.1
KB
-rw-r--r--
pickletools.pyo
55.26
KB
-rw-r--r--
pipes.py
9.36
KB
-rw-r--r--
pipes.pyc
9.29
KB
-rw-r--r--
pipes.pyo
9.29
KB
-rw-r--r--
pkgutil.py
19.77
KB
-rw-r--r--
pkgutil.pyc
18.93
KB
-rw-r--r--
pkgutil.pyo
18.93
KB
-rw-r--r--
platform.py
51.56
KB
-rwxr-xr-x
platform.pyc
37.7
KB
-rw-r--r--
platform.pyo
37.7
KB
-rw-r--r--
plistlib.py
14.83
KB
-rw-r--r--
plistlib.pyc
19.54
KB
-rw-r--r--
plistlib.pyo
19.46
KB
-rw-r--r--
popen2.py
8.22
KB
-rw-r--r--
popen2.pyc
9.02
KB
-rw-r--r--
popen2.pyo
8.98
KB
-rw-r--r--
poplib.py
12.52
KB
-rw-r--r--
poplib.pyc
13.45
KB
-rw-r--r--
poplib.pyo
13.45
KB
-rw-r--r--
posixfile.py
7.82
KB
-rw-r--r--
posixfile.pyc
7.63
KB
-rw-r--r--
posixfile.pyo
7.63
KB
-rw-r--r--
posixpath.py
13.96
KB
-rw-r--r--
posixpath.pyc
11.49
KB
-rw-r--r--
posixpath.pyo
11.49
KB
-rw-r--r--
pprint.py
11.5
KB
-rw-r--r--
pprint.pyc
10.2
KB
-rw-r--r--
pprint.pyo
10.02
KB
-rw-r--r--
profile.py
22.26
KB
-rwxr-xr-x
profile.pyc
16.57
KB
-rw-r--r--
profile.pyo
16.32
KB
-rw-r--r--
pstats.py
26.09
KB
-rw-r--r--
pstats.pyc
25.19
KB
-rw-r--r--
pstats.pyo
25.19
KB
-rw-r--r--
pty.py
4.94
KB
-rw-r--r--
pty.pyc
4.98
KB
-rw-r--r--
pty.pyo
4.98
KB
-rw-r--r--
py_compile.py
5.8
KB
-rw-r--r--
py_compile.pyc
6.37
KB
-rw-r--r--
py_compile.pyo
6.37
KB
-rw-r--r--
pyclbr.py
13.07
KB
-rw-r--r--
pyclbr.pyc
9.59
KB
-rw-r--r--
pyclbr.pyo
9.59
KB
-rw-r--r--
pydoc.py
93.43
KB
-rwxr-xr-x
pydoc.pyc
92.69
KB
-rw-r--r--
pydoc.pyo
92.63
KB
-rw-r--r--
quopri.py
6.81
KB
-rwxr-xr-x
quopri.pyc
6.56
KB
-rw-r--r--
quopri.pyo
6.56
KB
-rw-r--r--
random.py
31.7
KB
-rw-r--r--
random.pyc
25.65
KB
-rw-r--r--
random.pyo
25.65
KB
-rw-r--r--
re.py
13.11
KB
-rw-r--r--
re.pyc
13.37
KB
-rw-r--r--
re.pyo
13.37
KB
-rw-r--r--
repr.py
4.2
KB
-rw-r--r--
repr.pyc
5.47
KB
-rw-r--r--
repr.pyo
5.47
KB
-rw-r--r--
rexec.py
19.68
KB
-rw-r--r--
rexec.pyc
24
KB
-rw-r--r--
rexec.pyo
24
KB
-rw-r--r--
rfc822.py
32.76
KB
-rw-r--r--
rfc822.pyc
31.83
KB
-rw-r--r--
rfc822.pyo
31.83
KB
-rw-r--r--
rlcompleter.py
5.85
KB
-rw-r--r--
rlcompleter.pyc
6.04
KB
-rw-r--r--
rlcompleter.pyo
6.04
KB
-rw-r--r--
robotparser.py
7.51
KB
-rw-r--r--
robotparser.pyc
8.12
KB
-rw-r--r--
robotparser.pyo
8.12
KB
-rw-r--r--
runpy.py
10.82
KB
-rw-r--r--
runpy.pyc
8.85
KB
-rw-r--r--
runpy.pyo
8.85
KB
-rw-r--r--
sched.py
4.97
KB
-rw-r--r--
sched.pyc
4.99
KB
-rw-r--r--
sched.pyo
4.99
KB
-rw-r--r--
sets.py
18.6
KB
-rw-r--r--
sets.pyc
17.21
KB
-rw-r--r--
sets.pyo
17.21
KB
-rw-r--r--
sgmllib.py
17.46
KB
-rw-r--r--
sgmllib.pyc
15.67
KB
-rw-r--r--
sgmllib.pyo
15.67
KB
-rw-r--r--
sha.py
393
B
-rw-r--r--
sha.pyc
434
B
-rw-r--r--
sha.pyo
434
B
-rw-r--r--
shelve.py
7.99
KB
-rw-r--r--
shelve.pyc
10.36
KB
-rw-r--r--
shelve.pyo
10.36
KB
-rw-r--r--
shlex.py
10.9
KB
-rw-r--r--
shlex.pyc
7.55
KB
-rw-r--r--
shlex.pyo
7.55
KB
-rw-r--r--
shutil.py
19.41
KB
-rw-r--r--
shutil.pyc
19.19
KB
-rw-r--r--
shutil.pyo
19.19
KB
-rw-r--r--
site.py
19.18
KB
-rw-r--r--
site.pyc
19.35
KB
-rw-r--r--
site.pyo
19.35
KB
-rw-r--r--
smtpd.py
18.12
KB
-rwxr-xr-x
smtpd.pyc
15.9
KB
-rw-r--r--
smtpd.pyo
15.9
KB
-rw-r--r--
smtplib.py
31.39
KB
-rwxr-xr-x
smtplib.pyc
30.29
KB
-rw-r--r--
smtplib.pyo
30.29
KB
-rw-r--r--
sndhdr.py
5.83
KB
-rw-r--r--
sndhdr.pyc
7.4
KB
-rw-r--r--
sndhdr.pyo
7.4
KB
-rw-r--r--
socket.py
20.13
KB
-rw-r--r--
socket.pyc
16.15
KB
-rw-r--r--
socket.pyo
16.07
KB
-rw-r--r--
sre.py
384
B
-rw-r--r--
sre.pyc
532
B
-rw-r--r--
sre.pyo
532
B
-rw-r--r--
sre_compile.py
19.36
KB
-rw-r--r--
sre_compile.pyc
12.46
KB
-rw-r--r--
sre_compile.pyo
12.3
KB
-rw-r--r--
sre_constants.py
7.03
KB
-rw-r--r--
sre_constants.pyc
6.11
KB
-rw-r--r--
sre_constants.pyo
6.11
KB
-rw-r--r--
sre_parse.py
29.98
KB
-rw-r--r--
sre_parse.pyc
21.12
KB
-rw-r--r--
sre_parse.pyo
21.12
KB
-rw-r--r--
ssl.py
36.58
KB
-rw-r--r--
ssl.pyc
32.24
KB
-rw-r--r--
ssl.pyo
32.24
KB
-rw-r--r--
stat.py
1.8
KB
-rw-r--r--
stat.pyc
2.81
KB
-rw-r--r--
stat.pyo
2.81
KB
-rw-r--r--
statvfs.py
898
B
-rw-r--r--
statvfs.pyc
633
B
-rw-r--r--
statvfs.pyo
633
B
-rw-r--r--
string.py
21.04
KB
-rw-r--r--
string.pyc
20.63
KB
-rw-r--r--
string.pyo
20.63
KB
-rw-r--r--
stringold.py
12.16
KB
-rw-r--r--
stringold.pyc
12.6
KB
-rw-r--r--
stringold.pyo
12.6
KB
-rw-r--r--
stringprep.py
13.21
KB
-rw-r--r--
stringprep.pyc
14.4
KB
-rw-r--r--
stringprep.pyo
14.33
KB
-rw-r--r--
struct.py
82
B
-rw-r--r--
struct.pyc
252
B
-rw-r--r--
struct.pyo
252
B
-rw-r--r--
subprocess.py
49.34
KB
-rw-r--r--
subprocess.pyc
32.32
KB
-rw-r--r--
subprocess.pyo
32.32
KB
-rw-r--r--
sunau.py
16.82
KB
-rw-r--r--
sunau.pyc
18.57
KB
-rw-r--r--
sunau.pyo
18.57
KB
-rw-r--r--
sunaudio.py
1.37
KB
-rw-r--r--
sunaudio.pyc
2
KB
-rw-r--r--
sunaudio.pyo
2
KB
-rw-r--r--
symbol.py
2.02
KB
-rwxr-xr-x
symbol.pyc
2.98
KB
-rw-r--r--
symbol.pyo
2.98
KB
-rw-r--r--
symtable.py
7.26
KB
-rw-r--r--
symtable.pyc
12.14
KB
-rw-r--r--
symtable.pyo
12.02
KB
-rw-r--r--
sysconfig.py
22.32
KB
-rw-r--r--
sysconfig.pyc
17.73
KB
-rw-r--r--
sysconfig.pyo
17.73
KB
-rw-r--r--
tabnanny.py
11.08
KB
-rwxr-xr-x
tabnanny.pyc
8.31
KB
-rw-r--r--
tabnanny.pyo
8.31
KB
-rw-r--r--
tarfile.py
88.45
KB
-rw-r--r--
tarfile.pyc
76.54
KB
-rw-r--r--
tarfile.pyo
76.54
KB
-rw-r--r--
telnetlib.py
26.4
KB
-rw-r--r--
telnetlib.pyc
23.03
KB
-rw-r--r--
telnetlib.pyo
23.03
KB
-rw-r--r--
tempfile.py
19.09
KB
-rw-r--r--
tempfile.pyc
20.55
KB
-rw-r--r--
tempfile.pyo
20.55
KB
-rw-r--r--
textwrap.py
16.88
KB
-rw-r--r--
textwrap.pyc
11.99
KB
-rw-r--r--
textwrap.pyo
11.9
KB
-rw-r--r--
this.py
1002
B
-rw-r--r--
this.pyc
1.2
KB
-rw-r--r--
this.pyo
1.2
KB
-rw-r--r--
threading.py
46.17
KB
-rw-r--r--
threading.pyc
42.97
KB
-rw-r--r--
threading.pyo
40.84
KB
-rw-r--r--
timeit.py
12.5
KB
-rwxr-xr-x
timeit.pyc
12.06
KB
-rw-r--r--
timeit.pyo
12.06
KB
-rw-r--r--
toaiff.py
3.07
KB
-rw-r--r--
toaiff.pyc
3.08
KB
-rw-r--r--
toaiff.pyo
3.08
KB
-rw-r--r--
token.py
2.85
KB
-rw-r--r--
token.pyc
3.79
KB
-rw-r--r--
token.pyo
3.79
KB
-rw-r--r--
tokenize.py
17.07
KB
-rw-r--r--
tokenize.pyc
14.37
KB
-rw-r--r--
tokenize.pyo
14.31
KB
-rw-r--r--
trace.py
29.2
KB
-rwxr-xr-x
trace.pyc
22.69
KB
-rw-r--r--
trace.pyo
22.63
KB
-rw-r--r--
traceback.py
11.02
KB
-rw-r--r--
traceback.pyc
11.66
KB
-rw-r--r--
traceback.pyo
11.66
KB
-rw-r--r--
tty.py
879
B
-rw-r--r--
tty.pyc
1.32
KB
-rw-r--r--
tty.pyo
1.32
KB
-rw-r--r--
types.py
2.04
KB
-rw-r--r--
types.pyc
2.75
KB
-rw-r--r--
types.pyo
2.75
KB
-rw-r--r--
urllib.py
58.82
KB
-rw-r--r--
urllib.pyc
51.35
KB
-rw-r--r--
urllib.pyo
51.25
KB
-rw-r--r--
urllib2.py
51.31
KB
-rw-r--r--
urllib2.pyc
47.8
KB
-rw-r--r--
urllib2.pyo
47.71
KB
-rw-r--r--
urlparse.py
16.29
KB
-rw-r--r--
urlparse.pyc
15.51
KB
-rw-r--r--
urlparse.pyo
15.51
KB
-rw-r--r--
user.py
1.59
KB
-rw-r--r--
user.pyc
1.7
KB
-rw-r--r--
user.pyo
1.7
KB
-rw-r--r--
uu.py
6.55
KB
-rwxr-xr-x
uu.pyc
4.35
KB
-rw-r--r--
uu.pyo
4.35
KB
-rw-r--r--
uuid.py
22.63
KB
-rw-r--r--
uuid.pyc
23.22
KB
-rw-r--r--
uuid.pyo
23.11
KB
-rw-r--r--
warnings.py
14.48
KB
-rw-r--r--
warnings.pyc
13.49
KB
-rw-r--r--
warnings.pyo
12.71
KB
-rw-r--r--
wave.py
18.15
KB
-rw-r--r--
wave.pyc
20.19
KB
-rw-r--r--
wave.pyo
20.05
KB
-rw-r--r--
weakref.py
14.48
KB
-rw-r--r--
weakref.pyc
16.73
KB
-rw-r--r--
weakref.pyo
16.73
KB
-rw-r--r--
webbrowser.py
22.2
KB
-rwxr-xr-x
webbrowser.pyc
19.86
KB
-rw-r--r--
webbrowser.pyo
19.81
KB
-rw-r--r--
whichdb.py
3.31
KB
-rw-r--r--
whichdb.pyc
2.21
KB
-rw-r--r--
whichdb.pyo
2.21
KB
-rw-r--r--
wsgiref.egg-info
187
B
-rw-r--r--
xdrlib.py
5.93
KB
-rw-r--r--
xdrlib.pyc
10.2
KB
-rw-r--r--
xdrlib.pyo
10.2
KB
-rw-r--r--
xmllib.py
34.05
KB
-rw-r--r--
xmllib.pyc
26.9
KB
-rw-r--r--
xmllib.pyo
26.9
KB
-rw-r--r--
xmlrpclib.py
50.91
KB
-rw-r--r--
xmlrpclib.pyc
44.81
KB
-rw-r--r--
xmlrpclib.pyo
44.63
KB
-rw-r--r--
zipfile.py
58.08
KB
-rw-r--r--
zipfile.pyc
41.92
KB
-rw-r--r--
zipfile.pyo
41.92
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : HTMLParser.py
"""A parser for HTML and XHTML.""" # This file is based on sgmllib.py, but the API is slightly different. # XXX There should be a way to distinguish between PCDATA (parsed # character data -- the normal case), RCDATA (replaceable character # data -- only char and entity references and end tags are special) # and CDATA (character data -- only end tags are special). import markupbase import re # Regular expressions used for parsing interesting_normal = re.compile('[&<]') incomplete = re.compile('&[a-zA-Z#]') entityref = re.compile('&([a-zA-Z][-.a-zA-Z0-9]*)[^a-zA-Z0-9]') charref = re.compile('&#(?:[0-9]+|[xX][0-9a-fA-F]+)[^0-9a-fA-F]') starttagopen = re.compile('<[a-zA-Z]') piclose = re.compile('>') commentclose = re.compile(r'--\s*>') # see http://www.w3.org/TR/html5/tokenization.html#tag-open-state # and http://www.w3.org/TR/html5/tokenization.html#tag-name-state # note: if you change tagfind/attrfind remember to update locatestarttagend too tagfind = re.compile('([a-zA-Z][^\t\n\r\f />\x00]*)(?:\s|/(?!>))*') # this regex is currently unused, but left for backward compatibility tagfind_tolerant = re.compile('[a-zA-Z][^\t\n\r\f />\x00]*') attrfind = re.compile( r'((?<=[\'"\s/])[^\s/>][^\s/=>]*)(\s*=+\s*' r'(\'[^\']*\'|"[^"]*"|(?![\'"])[^>\s]*))?(?:\s|/(?!>))*') locatestarttagend = re.compile(r""" <[a-zA-Z][^\t\n\r\f />\x00]* # tag name (?:[\s/]* # optional whitespace before attribute name (?:(?<=['"\s/])[^\s/>][^\s/=>]* # attribute name (?:\s*=+\s* # value indicator (?:'[^']*' # LITA-enclosed value |"[^"]*" # LIT-enclosed value |(?!['"])[^>\s]* # bare value ) )?(?:\s|/(?!>))* )* )? \s* # trailing whitespace """, re.VERBOSE) endendtag = re.compile('>') # the HTML 5 spec, section 8.1.2.2, doesn't allow spaces between # </ and the tag name, so maybe this should be fixed endtagfind = re.compile('</\s*([a-zA-Z][-.a-zA-Z0-9:_]*)\s*>') class HTMLParseError(Exception): """Exception raised for all parse errors.""" def __init__(self, msg, position=(None, None)): assert msg self.msg = msg self.lineno = position[0] self.offset = position[1] def __str__(self): result = self.msg if self.lineno is not None: result = result + ", at line %d" % self.lineno if self.offset is not None: result = result + ", column %d" % (self.offset + 1) return result class HTMLParser(markupbase.ParserBase): """Find tags and other markup and call handler functions. Usage: p = HTMLParser() p.feed(data) ... p.close() Start tags are handled by calling self.handle_starttag() or self.handle_startendtag(); end tags by self.handle_endtag(). The data between tags is passed from the parser to the derived class by calling self.handle_data() with the data as argument (the data may be split up in arbitrary chunks). Entity references are passed by calling self.handle_entityref() with the entity reference as the argument. Numeric character references are passed to self.handle_charref() with the string containing the reference as the argument. """ CDATA_CONTENT_ELEMENTS = ("script", "style") def __init__(self): """Initialize and reset this instance.""" self.reset() def reset(self): """Reset this instance. Loses all unprocessed data.""" self.rawdata = '' self.lasttag = '???' self.interesting = interesting_normal self.cdata_elem = None markupbase.ParserBase.reset(self) def feed(self, data): r"""Feed data to the parser. Call this as often as you want, with as little or as much text as you want (may include '\n'). """ self.rawdata = self.rawdata + data self.goahead(0) def close(self): """Handle any buffered data.""" self.goahead(1) def error(self, message): raise HTMLParseError(message, self.getpos()) __starttag_text = None def get_starttag_text(self): """Return full source of start tag: '<...>'.""" return self.__starttag_text def set_cdata_mode(self, elem): self.cdata_elem = elem.lower() self.interesting = re.compile(r'</\s*%s\s*>' % self.cdata_elem, re.I) def clear_cdata_mode(self): self.interesting = interesting_normal self.cdata_elem = None # 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: match = self.interesting.search(rawdata, i) # < or & if match: j = match.start() else: if self.cdata_elem: break j = n if i < j: self.handle_data(rawdata[i:j]) i = self.updatepos(i, j) if i == n: break startswith = rawdata.startswith if startswith('<', i): if starttagopen.match(rawdata, i): # < + letter k = self.parse_starttag(i) elif startswith("</", i): k = self.parse_endtag(i) elif startswith("<!--", i): k = self.parse_comment(i) elif startswith("<?", i): k = self.parse_pi(i) elif startswith("<!", i): k = self.parse_html_declaration(i) elif (i + 1) < n: self.handle_data("<") k = i + 1 else: break if k < 0: if not end: break k = rawdata.find('>', i + 1) if k < 0: k = rawdata.find('<', i + 1) if k < 0: k = i + 1 else: k += 1 self.handle_data(rawdata[i:k]) i = self.updatepos(i, k) elif startswith("&#", i): match = charref.match(rawdata, i) if match: name = match.group()[2:-1] self.handle_charref(name) k = match.end() if not startswith(';', k-1): k = k - 1 i = self.updatepos(i, k) continue else: if ";" in rawdata[i:]: # bail by consuming '&#' self.handle_data(rawdata[i:i+2]) i = self.updatepos(i, i+2) break elif startswith('&', i): match = entityref.match(rawdata, i) if match: name = match.group(1) self.handle_entityref(name) k = match.end() if not startswith(';', k-1): k = k - 1 i = self.updatepos(i, k) continue match = incomplete.match(rawdata, i) if match: # match.group() will contain at least 2 chars if end and match.group() == rawdata[i:]: self.error("EOF in middle of entity or char ref") # incomplete break elif (i + 1) < n: # not the end of the buffer, and can't be confused # with some other construct self.handle_data("&") i = self.updatepos(i, i + 1) else: break else: assert 0, "interesting.search() lied" # end while if end and i < n and not self.cdata_elem: self.handle_data(rawdata[i:n]) i = self.updatepos(i, n) self.rawdata = rawdata[i:] # Internal -- parse html declarations, return length or -1 if not terminated # See w3.org/TR/html5/tokenization.html#markup-declaration-open-state # See also parse_declaration in _markupbase def parse_html_declaration(self, i): rawdata = self.rawdata if rawdata[i:i+2] != '<!': self.error('unexpected call to parse_html_declaration()') if rawdata[i:i+4] == '<!--': # this case is actually already handled in goahead() return self.parse_comment(i) elif rawdata[i:i+3] == '<![': return self.parse_marked_section(i) elif rawdata[i:i+9].lower() == '<!doctype': # find the closing > gtpos = rawdata.find('>', i+9) if gtpos == -1: return -1 self.handle_decl(rawdata[i+2:gtpos]) return gtpos+1 else: return self.parse_bogus_comment(i) # Internal -- parse bogus comment, return length or -1 if not terminated # see http://www.w3.org/TR/html5/tokenization.html#bogus-comment-state def parse_bogus_comment(self, i, report=1): rawdata = self.rawdata if rawdata[i:i+2] not in ('<!', '</'): self.error('unexpected call to parse_comment()') pos = rawdata.find('>', i+2) if pos == -1: return -1 if report: self.handle_comment(rawdata[i+2:pos]) return pos + 1 # Internal -- parse processing instr, return end or -1 if not terminated def parse_pi(self, i): rawdata = self.rawdata assert rawdata[i:i+2] == '<?', 'unexpected call to parse_pi()' match = piclose.search(rawdata, i+2) # > if not match: return -1 j = match.start() self.handle_pi(rawdata[i+2: j]) j = match.end() return j # Internal -- handle starttag, return end or -1 if not terminated def parse_starttag(self, i): self.__starttag_text = None endpos = self.check_for_whole_start_tag(i) if endpos < 0: return endpos rawdata = self.rawdata self.__starttag_text = rawdata[i:endpos] # Now parse the data between i+1 and j into a tag and attrs attrs = [] match = tagfind.match(rawdata, i+1) assert match, 'unexpected call to parse_starttag()' k = match.end() self.lasttag = tag = match.group(1).lower() while k < endpos: m = attrfind.match(rawdata, k) if not m: break attrname, rest, attrvalue = m.group(1, 2, 3) if not rest: attrvalue = None elif attrvalue[:1] == '\'' == attrvalue[-1:] or \ attrvalue[:1] == '"' == attrvalue[-1:]: attrvalue = attrvalue[1:-1] if attrvalue: attrvalue = self.unescape(attrvalue) attrs.append((attrname.lower(), attrvalue)) k = m.end() end = rawdata[k:endpos].strip() if end not in (">", "/>"): lineno, offset = self.getpos() if "\n" in self.__starttag_text: lineno = lineno + self.__starttag_text.count("\n") offset = len(self.__starttag_text) \ - self.__starttag_text.rfind("\n") else: offset = offset + len(self.__starttag_text) self.handle_data(rawdata[i:endpos]) return endpos if end.endswith('/>'): # XHTML-style empty tag: <span attr="value" /> self.handle_startendtag(tag, attrs) else: self.handle_starttag(tag, attrs) if tag in self.CDATA_CONTENT_ELEMENTS: self.set_cdata_mode(tag) return endpos # Internal -- check to see if we have a complete starttag; return end # or -1 if incomplete. def check_for_whole_start_tag(self, i): rawdata = self.rawdata m = locatestarttagend.match(rawdata, i) if m: j = m.end() next = rawdata[j:j+1] if next == ">": return j + 1 if next == "/": if rawdata.startswith("/>", j): return j + 2 if rawdata.startswith("/", j): # buffer boundary return -1 # else bogus input self.updatepos(i, j + 1) self.error("malformed empty start tag") if next == "": # end of input return -1 if next in ("abcdefghijklmnopqrstuvwxyz=/" "ABCDEFGHIJKLMNOPQRSTUVWXYZ"): # end of input in or before attribute value, or we have the # '/' from a '/>' ending return -1 if j > i: return j else: return i + 1 raise AssertionError("we should not get here!") # Internal -- parse endtag, return end or -1 if incomplete def parse_endtag(self, i): rawdata = self.rawdata assert rawdata[i:i+2] == "</", "unexpected call to parse_endtag" match = endendtag.search(rawdata, i+1) # > if not match: return -1 gtpos = match.end() match = endtagfind.match(rawdata, i) # </ + tag + > if not match: if self.cdata_elem is not None: self.handle_data(rawdata[i:gtpos]) return gtpos # find the name: w3.org/TR/html5/tokenization.html#tag-name-state namematch = tagfind.match(rawdata, i+2) if not namematch: # w3.org/TR/html5/tokenization.html#end-tag-open-state if rawdata[i:i+3] == '</>': return i+3 else: return self.parse_bogus_comment(i) tagname = namematch.group(1).lower() # consume and ignore other stuff between the name and the > # Note: this is not 100% correct, since we might have things like # </tag attr=">">, but looking for > after tha name should cover # most of the cases and is much simpler gtpos = rawdata.find('>', namematch.end()) self.handle_endtag(tagname) return gtpos+1 elem = match.group(1).lower() # script or style if self.cdata_elem is not None: if elem != self.cdata_elem: self.handle_data(rawdata[i:gtpos]) return gtpos self.handle_endtag(elem) self.clear_cdata_mode() return gtpos # Overridable -- finish processing of start+end tag: <tag.../> def handle_startendtag(self, tag, attrs): self.handle_starttag(tag, attrs) self.handle_endtag(tag) # Overridable -- handle start tag def handle_starttag(self, tag, attrs): pass # Overridable -- handle end tag def handle_endtag(self, tag): pass # Overridable -- handle character reference def handle_charref(self, name): pass # Overridable -- handle entity reference def handle_entityref(self, name): pass # Overridable -- handle data def handle_data(self, data): pass # Overridable -- handle comment def handle_comment(self, data): pass # Overridable -- handle declaration def handle_decl(self, decl): pass # Overridable -- handle processing instruction def handle_pi(self, data): pass def unknown_decl(self, data): pass # Internal -- helper to remove special character quoting entitydefs = None def unescape(self, s): if '&' not in s: return s def replaceEntities(s): s = s.groups()[0] try: if s[0] == "#": s = s[1:] if s[0] in ['x','X']: c = int(s[1:], 16) else: c = int(s) return unichr(c) except ValueError: return '&#'+s+';' else: # Cannot use name2codepoint directly, because HTMLParser supports apos, # which is not part of HTML 4 if HTMLParser.entitydefs is None: import htmlentitydefs entitydefs = {'apos':u"'"} for k, v in htmlentitydefs.name2codepoint.iteritems(): entitydefs[k] = unichr(v) HTMLParser.entitydefs = entitydefs try: return self.entitydefs[s] except KeyError: return '&'+s+';' return re.sub(r"&(#?[xX]?(?:[0-9a-fA-F]+|\w{1,8}));", replaceEntities, s)
Close