diff --git a/img/70.png b/img/70.png new file mode 100644 index 0000000..b6cb6b7 Binary files /dev/null and b/img/70.png differ diff --git a/img/71.png b/img/71.png new file mode 100644 index 0000000..14101a6 Binary files /dev/null and b/img/71.png differ diff --git a/img/72.png b/img/72.png new file mode 100644 index 0000000..1f664a7 Binary files /dev/null and b/img/72.png differ diff --git a/猿人学第4题-css图片字体-css样式隐藏/js代码4.js b/猿人学第4题-css图片字体-css样式隐藏/js代码4.js new file mode 100644 index 0000000..334d38f --- /dev/null +++ b/猿人学第4题-css图片字体-css样式隐藏/js代码4.js @@ -0,0 +1,204 @@ +var hexcase = 0; +var b64pad = ""; +var chrsz = 8; + +function hex_md5(s) { + return binl2hex(core_md5(str2binl(s), s.length * chrsz)) +} + +function b64_md5(s) { + return binl2b64(core_md5(str2binl(s), s.length * chrsz)) +} + +function str_md5(s) { + return binl2str(core_md5(str2binl(s), s.length * chrsz)) +} + +function hex_hmac_md5(key, data) { + return binl2hex(core_hmac_md5(key, data)) +} + +function b64_hmac_md5(key, data) { + return binl2b64(core_hmac_md5(key, data)) +} + +function str_hmac_md5(key, data) { + return binl2str(core_hmac_md5(key, data)) +} + +function md5_vm_test() { + return hex_md5("abc") == "900150983cd24fb0d6963f7d28e17f72" +} + +function core_md5(x, len) { + x[len >> 5] |= 0x80 << ((len) % 32); + x[(((len + 64) >>> 9) << 4) + 14] = len; + var a = 1732584193; + var b = -271733879; + var c = -1732584194; + var d = 271733878; + for (var i = 0; i < x.length; i += 16) { + var olda = a; + var oldb = b; + var oldc = c; + var oldd = d; + a = md5_ff(a, b, c, d, x[i + 0], 7, -680876936); + d = md5_ff(d, a, b, c, x[i + 1], 12, -389564586); + c = md5_ff(c, d, a, b, x[i + 2], 17, 606105819); + b = md5_ff(b, c, d, a, x[i + 3], 22, -1044525330); + a = md5_ff(a, b, c, d, x[i + 4], 7, -176418897); + d = md5_ff(d, a, b, c, x[i + 5], 12, 1200080426); + c = md5_ff(c, d, a, b, x[i + 6], 17, -1473231341); + b = md5_ff(b, c, d, a, x[i + 7], 22, -45705983); + a = md5_ff(a, b, c, d, x[i + 8], 7, 1770035416); + d = md5_ff(d, a, b, c, x[i + 9], 12, -1958414417); + c = md5_ff(c, d, a, b, x[i + 10], 17, -42063); + b = md5_ff(b, c, d, a, x[i + 11], 22, -1990404162); + a = md5_ff(a, b, c, d, x[i + 12], 7, 1804603682); + d = md5_ff(d, a, b, c, x[i + 13], 12, -40341101); + c = md5_ff(c, d, a, b, x[i + 14], 17, -1502002290); + b = md5_ff(b, c, d, a, x[i + 15], 22, 1236535329); + a = md5_gg(a, b, c, d, x[i + 1], 5, -165796510); + d = md5_gg(d, a, b, c, x[i + 6], 9, -1069501632); + c = md5_gg(c, d, a, b, x[i + 11], 14, 643717713); + b = md5_gg(b, c, d, a, x[i + 0], 20, -373897302); + a = md5_gg(a, b, c, d, x[i + 5], 5, -701558691); + d = md5_gg(d, a, b, c, x[i + 10], 9, 38016083); + c = md5_gg(c, d, a, b, x[i + 15], 14, -660478335); + b = md5_gg(b, c, d, a, x[i + 4], 20, -405537848); + a = md5_gg(a, b, c, d, x[i + 9], 5, 568446438); + d = md5_gg(d, a, b, c, x[i + 14], 9, -1019803690); + c = md5_gg(c, d, a, b, x[i + 3], 14, -187363961); + b = md5_gg(b, c, d, a, x[i + 8], 20, 1163531501); + a = md5_gg(a, b, c, d, x[i + 13], 5, -1444681467); + d = md5_gg(d, a, b, c, x[i + 2], 9, -51403784); + c = md5_gg(c, d, a, b, x[i + 7], 14, 1735328473); + b = md5_gg(b, c, d, a, x[i + 12], 20, -1926607734); + a = md5_hh(a, b, c, d, x[i + 5], 4, -378558); + d = md5_hh(d, a, b, c, x[i + 8], 11, -2022574463); + c = md5_hh(c, d, a, b, x[i + 11], 16, 1839030562); + b = md5_hh(b, c, d, a, x[i + 14], 23, -35309556); + a = md5_hh(a, b, c, d, x[i + 1], 4, -1530992060); + d = md5_hh(d, a, b, c, x[i + 4], 11, 1272893353); + c = md5_hh(c, d, a, b, x[i + 7], 16, -155497632); + b = md5_hh(b, c, d, a, x[i + 10], 23, -1094730640); + a = md5_hh(a, b, c, d, x[i + 13], 4, 681279174); + d = md5_hh(d, a, b, c, x[i + 0], 11, -358537222); + c = md5_hh(c, d, a, b, x[i + 3], 16, -722521979); + b = md5_hh(b, c, d, a, x[i + 6], 23, 76029189); + a = md5_hh(a, b, c, d, x[i + 9], 4, -640364487); + d = md5_hh(d, a, b, c, x[i + 12], 11, -421815835); + c = md5_hh(c, d, a, b, x[i + 15], 16, 530742520); + b = md5_hh(b, c, d, a, x[i + 2], 23, -995338651); + a = md5_ii(a, b, c, d, x[i + 0], 6, -198630844); + d = md5_ii(d, a, b, c, x[i + 7], 10, 1126891415); + c = md5_ii(c, d, a, b, x[i + 14], 15, -1416354905); + b = md5_ii(b, c, d, a, x[i + 5], 21, -57434055); + a = md5_ii(a, b, c, d, x[i + 12], 6, 1700485571); + d = md5_ii(d, a, b, c, x[i + 3], 10, -1894986606); + c = md5_ii(c, d, a, b, x[i + 10], 15, -1051523); + b = md5_ii(b, c, d, a, x[i + 1], 21, -2054922799); + a = md5_ii(a, b, c, d, x[i + 8], 6, 1873313359); + d = md5_ii(d, a, b, c, x[i + 15], 10, -30611744); + c = md5_ii(c, d, a, b, x[i + 6], 15, -1560198380); + b = md5_ii(b, c, d, a, x[i + 13], 21, 1309151649); + a = md5_ii(a, b, c, d, x[i + 4], 6, -145523070); + d = md5_ii(d, a, b, c, x[i + 11], 10, -1120210379); + c = md5_ii(c, d, a, b, x[i + 2], 15, 718787259); + b = md5_ii(b, c, d, a, x[i + 9], 21, -343485551); + a = safe_add(a, olda); + b = safe_add(b, oldb); + c = safe_add(c, oldc); + d = safe_add(d, oldd) + } + return Array(a, b, c, d) +} + +function md5_cmn(q, a, b, x, s, t) { + return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s), b) +} + +function md5_ff(a, b, c, d, x, s, t) { + return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t) +} + +function md5_gg(a, b, c, d, x, s, t) { + return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t) +} + +function md5_hh(a, b, c, d, x, s, t) { + return md5_cmn(b ^ c ^ d, a, b, x, s, t) +} + +function md5_ii(a, b, c, d, x, s, t) { + return md5_cmn(c ^ (b | (~d)), a, b, x, s, t) +} + +function core_hmac_md5(key, data) { + var bkey = str2binl(key); + if (bkey.length > 16) + bkey = core_md5(bkey, key.length * chrsz); + var ipad = Array(16) + , opad = Array(16); + for (var i = 0; i < 16; i++) { + ipad[i] = bkey[i] ^ 0x36363636; + opad[i] = bkey[i] ^ 0x5C5C5C5C + } + var hash = core_md5(ipad.concat(str2binl(data)), 512 + data.length * chrsz); + return core_md5(opad.concat(hash), 512 + 128) +} + +function safe_add(x, y) { + var lsw = (x & 0xFFFF) + (y & 0xFFFF); + var msw = (x >> 16) + (y >> 16) + (lsw >> 16); + return (msw << 16) | (lsw & 0xFFFF) +} + +function bit_rol(num, cnt) { + return (num << cnt) | (num >>> (32 - cnt)) +} + +function str2binl(str) { + var bin = Array(); + var mask = (1 << chrsz) - 1; + for (var i = 0; i < str.length * chrsz; i += chrsz) + bin[i >> 5] |= (str.charCodeAt(i / chrsz) & mask) << (i % 32); + return bin +} + +function binl2str(bin) { + var str = ""; + var mask = (1 << chrsz) - 1; + for (var i = 0; i < bin.length * 32; i += chrsz) + str += String.fromCharCode((bin[i >> 5] >>> (i % 32)) & mask); + return str +} + +function binl2hex(binarray) { + var hex_tab = hexcase ? "0123456789ABCDEF" : "0123456789abcdef"; + var str = ""; + for (var i = 0; i < binarray.length * 4; i++) { + str += hex_tab.charAt((binarray[i >> 2] >> ((i % 4) * 8 + 4)) & 0xF) + hex_tab.charAt((binarray[i >> 2] >> ((i % 4) * 8)) & 0xF) + } + return str +} + +function binl2b64(binarray) { + var tab = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; + var str = ""; + for (var i = 0; i < binarray.length * 4; i += 3) { + var triplet = (((binarray[i >> 2] >> 8 * (i % 4)) & 0xFF) << 16) | (((binarray[i + 1 >> 2] >> 8 * ((i + 1) % 4)) & 0xFF) << 8) | ((binarray[i + 2 >> 2] >> 8 * ((i + 2) % 4)) & 0xFF); + for (var j = 0; j < 4; j++) { + if (i * 8 + j * 6 > binarray.length * 32) + str += b64pad; + else + str += tab.charAt((triplet >> 6 * (3 - j)) & 0x3F) + } + } + return str +} + +module.exports = + { + hex_md5 + }; \ No newline at end of file diff --git a/猿人学第4题-css图片字体-css样式隐藏/readme.md b/猿人学第4题-css图片字体-css样式隐藏/readme.md new file mode 100644 index 0000000..5f40fd2 --- /dev/null +++ b/猿人学第4题-css图片字体-css样式隐藏/readme.md @@ -0,0 +1,277 @@ + +## 任务4:采集这5页的全部数字,计算加和并提交结果 + + https://match.yuanrenxue.com/match/4 + +先请求测试 + + info: " + + +style="left: 0px; display: none;" + + display 为css样式的隐藏,不显示 + left 向左的偏移量 + +通过图片的收集寻找出对应的0~9图片数字 + + "": 0, + "": 1, + "": 2, + "": 3, + "": 4, + "": 5, + "": 6, + "": 7, + "": 8, + "": 9 + +接下来就是对图片显示混淆,我们需要判断是否为隐藏 + +打断点尝试寻找css样式渲染代码 + +![debugger](../img/71.png) + + $(j_key).css('display', 'none'); + +j_key 的值是 ".d09288f99deb1477f74e2dcb7aa51aaf",很显然就是这段代码做的渲染 + +那么 d09288f99deb1477f74e2dcb7aa51aaf 怎么来的? + + var j_key = '.' + hex_md5(btoa(data.key + data.value).replace(/=/g, '')); + +其中的 data.key 和 data.value就是接口返回的数据 + + info: "> 5] |= 0x80 << ((len) % 32); + x[(((len + 64) >>> 9) << 4) + 14] = len; + var a = 1732584193; + var b = -271733879; + var c = -1732584194; + var d = 271733878; + for (var i = 0; i < x.length; i += 16) { + var olda = a; + var oldb = b; + var oldc = c; + var oldd = d; + a = md5_ff(a, b, c, d, x[i + 0], 7, -680876936); + d = md5_ff(d, a, b, c, x[i + 1], 12, -389564586); + c = md5_ff(c, d, a, b, x[i + 2], 17, 606105819); + b = md5_ff(b, c, d, a, x[i + 3], 22, -1044525330); + a = md5_ff(a, b, c, d, x[i + 4], 7, -176418897); + d = md5_ff(d, a, b, c, x[i + 5], 12, 1200080426); + c = md5_ff(c, d, a, b, x[i + 6], 17, -1473231341); + b = md5_ff(b, c, d, a, x[i + 7], 22, -45705983); + a = md5_ff(a, b, c, d, x[i + 8], 7, 1770035416); + d = md5_ff(d, a, b, c, x[i + 9], 12, -1958414417); + c = md5_ff(c, d, a, b, x[i + 10], 17, -42063); + b = md5_ff(b, c, d, a, x[i + 11], 22, -1990404162); + a = md5_ff(a, b, c, d, x[i + 12], 7, 1804603682); + d = md5_ff(d, a, b, c, x[i + 13], 12, -40341101); + c = md5_ff(c, d, a, b, x[i + 14], 17, -1502002290); + b = md5_ff(b, c, d, a, x[i + 15], 22, 1236535329); + a = md5_gg(a, b, c, d, x[i + 1], 5, -165796510); + d = md5_gg(d, a, b, c, x[i + 6], 9, -1069501632); + c = md5_gg(c, d, a, b, x[i + 11], 14, 643717713); + b = md5_gg(b, c, d, a, x[i + 0], 20, -373897302); + a = md5_gg(a, b, c, d, x[i + 5], 5, -701558691); + d = md5_gg(d, a, b, c, x[i + 10], 9, 38016083); + c = md5_gg(c, d, a, b, x[i + 15], 14, -660478335); + b = md5_gg(b, c, d, a, x[i + 4], 20, -405537848); + a = md5_gg(a, b, c, d, x[i + 9], 5, 568446438); + d = md5_gg(d, a, b, c, x[i + 14], 9, -1019803690); + c = md5_gg(c, d, a, b, x[i + 3], 14, -187363961); + b = md5_gg(b, c, d, a, x[i + 8], 20, 1163531501); + a = md5_gg(a, b, c, d, x[i + 13], 5, -1444681467); + d = md5_gg(d, a, b, c, x[i + 2], 9, -51403784); + c = md5_gg(c, d, a, b, x[i + 7], 14, 1735328473); + b = md5_gg(b, c, d, a, x[i + 12], 20, -1926607734); + a = md5_hh(a, b, c, d, x[i + 5], 4, -378558); + d = md5_hh(d, a, b, c, x[i + 8], 11, -2022574463); + c = md5_hh(c, d, a, b, x[i + 11], 16, 1839030562); + b = md5_hh(b, c, d, a, x[i + 14], 23, -35309556); + a = md5_hh(a, b, c, d, x[i + 1], 4, -1530992060); + d = md5_hh(d, a, b, c, x[i + 4], 11, 1272893353); + c = md5_hh(c, d, a, b, x[i + 7], 16, -155497632); + b = md5_hh(b, c, d, a, x[i + 10], 23, -1094730640); + a = md5_hh(a, b, c, d, x[i + 13], 4, 681279174); + d = md5_hh(d, a, b, c, x[i + 0], 11, -358537222); + c = md5_hh(c, d, a, b, x[i + 3], 16, -722521979); + b = md5_hh(b, c, d, a, x[i + 6], 23, 76029189); + a = md5_hh(a, b, c, d, x[i + 9], 4, -640364487); + d = md5_hh(d, a, b, c, x[i + 12], 11, -421815835); + c = md5_hh(c, d, a, b, x[i + 15], 16, 530742520); + b = md5_hh(b, c, d, a, x[i + 2], 23, -995338651); + a = md5_ii(a, b, c, d, x[i + 0], 6, -198630844); + d = md5_ii(d, a, b, c, x[i + 7], 10, 1126891415); + c = md5_ii(c, d, a, b, x[i + 14], 15, -1416354905); + b = md5_ii(b, c, d, a, x[i + 5], 21, -57434055); + a = md5_ii(a, b, c, d, x[i + 12], 6, 1700485571); + d = md5_ii(d, a, b, c, x[i + 3], 10, -1894986606); + c = md5_ii(c, d, a, b, x[i + 10], 15, -1051523); + b = md5_ii(b, c, d, a, x[i + 1], 21, -2054922799); + a = md5_ii(a, b, c, d, x[i + 8], 6, 1873313359); + d = md5_ii(d, a, b, c, x[i + 15], 10, -30611744); + c = md5_ii(c, d, a, b, x[i + 6], 15, -1560198380); + b = md5_ii(b, c, d, a, x[i + 13], 21, 1309151649); + a = md5_ii(a, b, c, d, x[i + 4], 6, -145523070); + d = md5_ii(d, a, b, c, x[i + 11], 10, -1120210379); + c = md5_ii(c, d, a, b, x[i + 2], 15, 718787259); + b = md5_ii(b, c, d, a, x[i + 9], 21, -343485551); + a = safe_add(a, olda); + b = safe_add(b, oldb); + c = safe_add(c, oldc); + d = safe_add(d, oldd) + } + return Array(a, b, c, d) + } + function md5_cmn(q, a, b, x, s, t) { + return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s), b) + } + function md5_ff(a, b, c, d, x, s, t) { + return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t) + } + function md5_gg(a, b, c, d, x, s, t) { + return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t) + } + function md5_hh(a, b, c, d, x, s, t) { + return md5_cmn(b ^ c ^ d, a, b, x, s, t) + } + function md5_ii(a, b, c, d, x, s, t) { + return md5_cmn(c ^ (b | (~d)), a, b, x, s, t) + } + function core_hmac_md5(key, data) { + var bkey = str2binl(key); + if (bkey.length > 16) + bkey = core_md5(bkey, key.length * chrsz); + var ipad = Array(16) + , opad = Array(16); + for (var i = 0; i < 16; i++) { + ipad[i] = bkey[i] ^ 0x36363636; + opad[i] = bkey[i] ^ 0x5C5C5C5C + } + var hash = core_md5(ipad.concat(str2binl(data)), 512 + data.length * chrsz); + return core_md5(opad.concat(hash), 512 + 128) + } + function safe_add(x, y) { + var lsw = (x & 0xFFFF) + (y & 0xFFFF); + var msw = (x >> 16) + (y >> 16) + (lsw >> 16); + return (msw << 16) | (lsw & 0xFFFF) + } + function bit_rol(num, cnt) { + return (num << cnt) | (num >>> (32 - cnt)) + } + function str2binl(str) { + var bin = Array(); + var mask = (1 << chrsz) - 1; + for (var i = 0; i < str.length * chrsz; i += chrsz) + bin[i >> 5] |= (str.charCodeAt(i / chrsz) & mask) << (i % 32); + return bin + } + function binl2str(bin) { + var str = ""; + var mask = (1 << chrsz) - 1; + for (var i = 0; i < bin.length * 32; i += chrsz) + str += String.fromCharCode((bin[i >> 5] >>> (i % 32)) & mask); + return str + } + function binl2hex(binarray) { + var hex_tab = hexcase ? "0123456789ABCDEF" : "0123456789abcdef"; + var str = ""; + for (var i = 0; i < binarray.length * 4; i++) { + str += hex_tab.charAt((binarray[i >> 2] >> ((i % 4) * 8 + 4)) & 0xF) + hex_tab.charAt((binarray[i >> 2] >> ((i % 4) * 8)) & 0xF) + } + return str + } + function binl2b64(binarray) { + var tab = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; + var str = ""; + for (var i = 0; i < binarray.length * 4; i += 3) { + var triplet = (((binarray[i >> 2] >> 8 * (i % 4)) & 0xFF) << 16) | (((binarray[i + 1 >> 2] >> 8 * ((i + 1) % 4)) & 0xFF) << 8) | ((binarray[i + 2 >> 2] >> 8 * ((i + 2) % 4)) & 0xFF); + for (var j = 0; j < 4; j++) { + if (i * 8 + j * 6 > binarray.length * 32) + str += b64pad; + else + str += tab.charAt((triplet >> 6 * (3 - j)) & 0x3F) + } + } + return str + } + +这以上内容都准备好后,请求数据,翻译图片内容,组成数据,发现数字的顺序是错误的. + +这里涉及到偏移量 left: 11.5px,仔细观察,没一个图片偏移量都是11.5倍数 + + 第一张图片就是 11.5*0 + 第二张图片就是 11.5*1 + 第三张图片就是 11.5*2 + 第四张图片就是 11.5*3 + +然后 left 参数就是控制其图片位置,几次操作发现 left 和图片位置存在的关系是 + + left - 当前图片标签所有存在位置 = 真实图片的位置 + +![debugger](../img/72.png) + +图片案例 + + left1 = 0 ===> 0+0=0 + left2 = 11.5 ===> 11.5+11.5=23 + left3 = -11.5 ===> -11.5+11.5*2=11.5 + left4 = 0 ===> 0+11.5*3=34.5 + +排序就是 + + left1,left3,left2,left4 + + +## 最后代码实现 + +[最后代码实现](js代码4.js "js代码4") + diff --git a/猿人学第4题-css图片字体-css样式隐藏/server4.js b/猿人学第4题-css图片字体-css样式隐藏/server4.js new file mode 100644 index 0000000..dffae0b --- /dev/null +++ b/猿人学第4题-css图片字体-css样式隐藏/server4.js @@ -0,0 +1,18 @@ +const express = require('express'); +const app = express(); +const encryption = require("./js代码4"); +var bodyParser = require('body-parser'); +app.use(bodyParser()); + + +app.post('/get_sign', function (req, res) { + let result = req.body; + let sign = result.sign; + console.log(sign); + result = encryption.hex_md5(sign); + res.send(result.toString()); +}); + +app.listen(4001, () => { + console.log("开启服务,端口 4001") +}); diff --git a/猿人学第4题-/实例1.py b/猿人学第4题-css图片字体-css样式隐藏/实例1.py similarity index 83% rename from 猿人学第4题-/实例1.py rename to 猿人学第4题-css图片字体-css样式隐藏/实例1.py index bdeec7b..31e52bc 100644 --- a/猿人学第4题-/实例1.py +++ b/猿人学第4题-css图片字体-css样式隐藏/实例1.py @@ -1,12 +1,29 @@ import requests import json from scrapy.selector import Selector +import base64 class 实例1(object): def __init__(self): - self.url = "https://match.yuanrenxue.com/api/match/4?page=1" + self.url = "https://match.yuanrenxue.com/api/match/4?page={}" + self.sign_url = "http://127.0.0.1:4001/get_sign" + self.num = 0 + + def get_sign(self, date_time): + data = { + 'sign': str(date_time) + } + req = requests.post(self.sign_url, data=data) + sign = req.text + return sign + + def get_md5(self, con_str): + ba_str = base64.b64encode(con_str.encode()) + ba_str = ba_str.decode().replace('=', '') + img_number_sign = self.get_sign(ba_str) + return img_number_sign def get_res(self): num_item = { @@ -22,17 +39,42 @@ class 实例1(object): "": 9 } - res = requests.get(url=self.url) - res_dict = json.loads(res.text) - info = res_dict.get('info') - selector = Selector(text=info, type='html') - td_list = selector.xpath('//td').extract() - for td in td_list: - td_sel = Selector(text=td, type='html') - img_list = td_sel.xpath('//img/@src').extract() - for img_url in img_list: - print(num_item[img_url]) - exit() + Headers = { + "user-agent": "yuanrenxue.project", + "cookie": "Hm_lvt_c99546cf032aaa5a679230de9a95c7db=1648698333,1648863299; " + "Hm_lpvt_c99546cf032aaa5a679230de9a95c7db=1648867785; qpfccr=true; no-alert3=true" + } + for j in range(1, 6): + res = requests.get(url=self.url.format(j), headers=Headers) + res_dict = json.loads(res.text) + info = res_dict.get('info') + key = res_dict.get('key') + value = res_dict.get('value') + img_number_sign = self.get_md5(key + value) + selector = Selector(text=info, type='html') + td_list = selector.xpath('//td').extract() + for td in td_list: + td_sel = Selector(text=td, type='html') + img_list = td_sel.xpath('//img').extract() + item_list = [] + i = 0 + item = {} + for img_str in img_list: + if img_number_sign in img_str: + continue + img_sel = Selector(text=img_str, type='html') + img_src = img_sel.xpath('//@src').extract_first() + img_number = img_sel.xpath('//@class').extract_first() + img_style = float(img_sel.xpath('//@style').extract_first().replace('left:', '').replace('px', '')) + item[img_style + i] = num_item[img_src] + i += 11.5 + + for i in sorted(item): + item_list.append(str(item[i])) + num = int(''.join(item_list)) + self.num += num + print(self.num) + exit() if __name__ == '__main__':