您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Рипалка ссылок / имён / номеров картинок
// ==UserScript== // @name Direct Image Link E6AI // @name:en Direct Image Link E6AI // @version 2025.03.30.1 // @description Рипалка ссылок / имён / номеров картинок // @description:en Ripper of image links / names / numbers // @match http*://e6ai.net/posts* // @match http*://e6ai.net/pool* // @match http*://e6ai.net/favorites* // @author Rainbow-Spike // @namespace https://greasyfork.org/users/7568 // @homepage https://greasyfork.org/ru/users/7568-rainbow-spike // @icon https://www.google.com/s2/favicons?domain=e6ai.net // @grant none // @run-at document-end // ==/UserScript== var post_list = document . querySelectorAll ( '.thumbnail' ); if ( post_list != null ) { var mode = 2, // 0 - номера постов post numbers, 1 - имена файлов file names, 2 - полные ссылки full links lever = { // 0 - нет no, 1 - да yes nl: 1, // использовать "чёрный список" тегов use tag negative list pl: 1, // использовать "белый список" тегов use tag positive list dl: 1, // фильтр уже скачанных картинок filter of already downloaded pics top: 1, // полный список вверху страницы full list on page top pic: 1, // вставка под каждой картинкой insertion under every pic }, tag = { nl: /^censored|gore|male\/male|my_little_pony/, pl: /[^_]pussy[^_]|female_on_top|animated|child_on_child|tribadism|camel_toe/, }, css = { // стили styles nl: 'opacity: 0.5; border: 3px dotted red;', // "чёрный список" negative list neut: 'opacity: 0.5; border: 3px dashed gray;', // вне "белого списка" out of positive list dl: 'opacity: 0.5; border: 16px double green;', // скачанное downloaded top: 'columns: 300px; font-size: 40%; line-height: .25em; max-height: 100px;', // колонки в полном списке columns in full list pic: 'word-wrap: anywhere;', // под каждой картинкой under every pic }, node = { top: document . querySelector ( 'body' ), new: document . createElement ( 'div' ), }, md5_list = [ // список MD5-кодов уже закачанных файлов, ВСТАВЬ СВОЙ СПИСОК list of MD5-codes of already downloaded files, INSERT YOUR LIST '00000000000000000000000000000000', '00000000000000000000000000000000' ], x, y, post_tags, src, name, md5, ext, num, insert; for ( x = 0; x < post_list . length; x++ ) { // получение данных data mining post_tags = post_list [ x ] . getAttribute ( 'data-tags' ); src = post_list [ x ] . getAttribute ( 'data-file-url' ); name = src . split ( '/' ) . pop ( ); [ md5, ext ] = name . split ( '.' ); num = post_list [ x ] . getAttribute ( 'data-id' ); // фильтрация filtering if ( md5 != '' && lever . nl && tag . nl . test ( post_tags ) ) { post_list [ x ] . style = css . nl; md5 = ''; }; // сначала "чёрный список" negative list in first if ( md5 != '' && lever . pl && !tag . pl . test ( post_tags ) ) { post_list [ x ] . style = css . neut; md5 = ''; }; // затем "белый список" positive list in middle if ( md5 != '' && lever . dl ) { // фильтр скачанного в конце filter of downloaded in last for ( y = 0; y < md5_list . length; y++ ) { if ( md5_list [ y ] == md5 ) { post_list [ x ] . style = css . dl; md5 = ''; break; }; }; }; if ( md5 != '' ) { if ( lever . top && node . top != null ) { // пополнение и режим полного списка complection and mode of full list switch ( mode ) { case 0: insert = num + '.' + ext; break; // номер поста + расширение post number + extension case 1: insert = name; break; // имя файла file name case 2: insert = src; break; // путь картинки pic path }; node . new . innerHTML += '<a href = "' + src + '">' + insert + ' </a><br>'; }; if ( lever . pic ) { switch ( mode ) { case 0: insert = num; break; // номер поста post number case 1: case 2: insert = md5; break; // MD5-код картинки pic MD5-code }; post_list [ x ] . innerHTML += '<a href = "' + src + '" style = "' + css . pic + '">' + insert + ' </a>'; // вставка MD5-кода под избранными картинками insertion of MD5-code under the chosen pics }; }; }; if ( lever . top && node . top != null ) { // вставка и выделение полного списка insertion and selection of full list node . new . style = css . top; node . top . insertBefore ( node . new, node . top . firstChild); function selectblock ( sel_node ) { var rng = document . createRange ( ); rng . selectNode ( sel_node ); var sel = window . getSelection ( ); sel . removeAllRanges ( ); sel . addRange ( rng ); }; selectblock ( node . new ); } }