🏠 Home 

批量提取动漫花园BT链接

筛选、提取、选择并复制动漫花园当前搜索结果的BT链接


Install this script?
// ==UserScript==
// @name         批量提取动漫花园BT链接
// @description  筛选、提取、选择并复制动漫花园当前搜索结果的BT链接
// @require      https://code.jquery.com/jquery-3.3.1.min.js
// @author       YD-Cat
// @version      1.66
// @namespace    https://greasyfork.org/zh-CN/users/242083-yd-cat
// @copyright    2019+, YD-Cat
// @include      http*://share.dmhy.org/*
// @icon         https://share.dmhy.org/favicon.ico
// ==/UserScript==
var $ = jQuery.noConflict();
var eventFun=function(){
//显示窗口
$("#extract").click(function(){
var magnetObjs=$('.download-arrow.arrow-magnet')
var titleObjs=$('td.title>a')
//显示或隐藏
if($('#magnetBox').css('display')!='block'){
//初始化内容
$('#magnetBox #selected').text(0)
$('#copySltDL>a').text('複製種子下载链接')
$('#selectAll').attr('flag',false)
//没有可提取资源
if(magnetObjs.length<=0||($('#topic_list>tbody>tr[class="mismatch"]').length==$('#topic_list>tbody>tr').length)){
let str='<tr style="text-align: center;" class="even"><td></td><td class="myTitle">没有资源</td><td></td></tr>';
$("#magnetUrl tbody").append(str);
show();
}
else{
var index=1;
//获取每一行
titleObjs.each((i,myThis)=>{
const tr =$(myThis).parents('#topic_list>tbody>tr');
//过滤不符合筛选的资源
if(!tr.hasClass('mismatch')){
let str='<tr style="text-align: center;" class="even"><td style="user-select: none;">'+ index++ +'</td><td class="align myTitle">'+titleObjs[i].innerText+'</td><td><input type="checkBox"></td><td class="align myDisplay magnet">'+magnetObjs[i].href.substring(0,magnetObjs[i].href.indexOf('&dn'))+'</td><td class="align myDisplay DL_Page">'+myThis.href+'</td><td class="align DL_Link myDisplay"></td></tr>'
$("#magnetUrl tbody").append(str);
}
})
show();
//加载种子下载链接
$('#copySltDL>a').text("加载中")
setTimeout(()=>{
$('#magnetUrl tbody>tr').each((i, node)=>{
if(i==$('#magnetUrl tbody>tr').length-1){
$('#copySltDL>a').text("複製種子下载链接")
}
$.ajax({
url: $(node).children('.DL_Page').text(),
//                             aysnc:false,
success: function (data) {
$(node).children('.DL_Link').text('https://'+data.match(/dl.dmhy.org(.*).torrent?/)[0])
}
})
})
},250);
}
}
else{
hide();
}
});
//全选
$("#selectAll").click(function(){
var flag=stringToBoolean($('#selectAll').attr('flag'))
$('#magnetUrl [type="checkBox"]').each(function(){this.checked= !flag})
$('#magnetBox #selected').text($('#magnetUrl :checked').length)
$('#selectAll').attr('flag',!flag)
if(stringToBoolean($('#selectAll').attr('flag'))){
$('#magnetUrl tbody>tr').each((i,node)=>{
$(node).addClass('checked');
});
}
else{
$('#magnetUrl tbody>tr').each((i,node)=>{
$(node).removeClass('checked');
});
}
});
//反选
$('#selectInvert').click(function(){
$('#magnetUrl [type="checkBox"]').each(function(){$(this).click()});
$('#magnetBox #selected').text($('#magnetUrl :checked').length);
isSelectAll()
});
//关闭窗口
$("#close").click(function(){
hide();
});
$(document).keydown((e)=>{if(e.keyCode==27) hide();})
//复制已选
$('#copySltMgnet').click(function(){
let str='';
$('#magnetUrl input:checked').each((i,node)=>{
str+=$(node).parent().next('.magnet').text()+'\n'
})
copy(str)
});
//复制已选下载链
$("#copySltDL").click(()=>{
if($("#copySltDL>a").text()=='複製種子下载链接'){
var str='';
$('#magnetUrl input:checked').each((i,node)=>{
str+=$(node).parent().nextAll('.DL_Link').text()+"\n";
})
copy(str)
}
})
//给选择框绑定点击事件
$(document).on('click','#magnetUrl [type="checkBox"]',function(event){
event.stopPropagation();
$(this).parents('tr').toggleClass('checked');
$('#magnetBox #selected').text($('#magnetUrl :checked').length);
isSelectAll();
});
$(document).on('click','#magnetUrl tbody>tr',function(){
let checkBox=$(this).find('input')[0];
if(checkBox!=null){
checkBox.checked=!checkBox.checked;
$('#magnetBox #selected').text($('#magnetUrl :checked').length);
$(this).toggleClass('checked');
isSelectAll();
}
});
//防止输入非正整数
$('#page').keypress(function(e){
return(/[\d]/.test(String.fromCharCode(event.keyCode)))
});
//跳转
$('#goToPage').click(function(){
let url='https://share.dmhy.org/topics/list/page/';
let page=$('#page').val();
let localUrl=window.location.href;
let KWpoint=localUrl.lastIndexOf('?keyword');
let keyword;
if(!(KWpoint>0)){
url+=page;
}
else{
keyword=localUrl.substring(KWpoint);
url+=page+keyword;
}
window.location.href=url;
});
$('#page').keypress(function(){
if(event.keyCode==13){
$('#goToPage').click()
}
})
//筛选
$('#filter').click(function(){
let regexList
try{
regexList=$('#condition').val().split(/[; :,,;]+/).map((r)=>new RegExp(r));
}
catch(error){
alert('筛选条件错误,请参考正则表达式')
}
$('#topic_list>tbody>tr').each(function(){
$(this).removeClass();
const tagA=this.querySelector('.title>a')
//筛选资源
const select = tagA && regexList.reduce((r###lt, regex) =>{return(r###lt && regex.test(tagA.textContent))}, true);
if(select==false){
$(this).addClass('mismatch');
}
else{
$(this).removeClass('mismatch');
}
//清除样式
$(this).removeClass('even');
$(this).removeClass('odd');
})
//重新设置样式
$('#topic_list>tbody>tr[class!="mismatch"]').each((i,node)=>{
if(i&1) $(node).addClass('odd')
else $(node).addClass('even')
});
})
$('#condition').keypress(()=>{
if(event.keyCode==13){
$('#filter').click()
}
})
};
(function() {
enhanced();
resourceTable();
//加载事件
eventFun();
})();
//增强功能
function enhanced(){
//添加样式
let style='<style type="text/css">.myDisplay{display:none;}.checked{background:#9bc6f6}.mismatch{display:none;}.myDiv>p{display:inline;}.line{font-size:16px;line-height:16px;margin:0 5px;}.myInput{position: relative;top: -2px;border: 1px solid #eee;font-size: 13px;}#page{width:3em;}#condition{width:10em;}.myLeft{margin-left: 5px;}#magnetBox{font-size: 13px;position: fixed;background: white;padding: 2px;display:none;border: 1px solid #247;}#magnetUrl{max-height: 405px;;overflow: auto;}#magnetUrl tr{cursor: default;}#magnetUrl thead>tr{background-color: #7e99be;color: white;font-size: 15px;}#magnetUrl th{padding:5px;}#magnetUrl tbody>tr:hover{background-color: #94aed7;}#magnetUrl tbody>tr:active{background-color: #8ab4f6;}#magnetUrl td{padding:6px 8px;color: #247;}.align{text-align: left;padding-left: 10px;}hr{margin:2px 0 0}#selectBox{margin:3px 2px 2px}#selectBox:after{content: "";display: block;clear: both;}#selectBox>ul{margin:0; padding:0;}#selectBox>ul>li{list-style-type: none;text-align: center;}#selectBox a{display:block;padding:5px;border:1px solid #247;}#selectBox>ul>li:nth-of-type(n+2){margin-left:10px;}#copySltDL{width:116px;}#copyText{position:absolute;top:-9999px;z-index:-999;width:0;height:0;opacity:0;}.myTitle{min-width:400px;max-width:580px;word-break: break-all;}input[type=number] {-moz-appearance:textfield;  }  input[type=number]::-webkit-inner-spin-button,  input[type=number]::-webkit-outer-spin-button {  -webkit-appearance: none;  margin: 0;  } </style>'
$('.table.clear').before(style)
//跳转
let goPage='<div class="fl myDiv"><p class="line">&nbsp;|&nbsp;</p><p style="display: inline;">跳轉</p><input type="number" id="page" class="myLeft myInput"><p style="display: inline;" class="myLeft">页</p><a href="javascript:void(0)" id="goToPage" class="myLeft">前往</a></div>';
//筛选
let filter='<div class="fl myDiv"><p class="line">&nbsp;|&nbsp;</p><p style="display: inline;">条件</p><input type="text" id="condition" class="myLeft myInput" title="请参考正则表达式"><a href="javascript:void(0)" id="filter" class="myLeft">筛选</a></div>';
//提取
let ExtractText='<div class="fl myDiv"><p class="line">&nbsp;|&nbsp;</p><a href="javascript:void(0)" id="extract">提取鏈接</a></div>'
//选择按钮
let TextBox='<div id="magnetBox"><div id="magnetUrl"><table border="0"><thead><tr><th width="30">序列</th><th>標題</th><th width="30">選擇</th><th class="myDisplay">磁鏈</th><th class="myDisplay">頁面</th><th class="myDisplay">下载鏈</th></tr></thead><tbody></tbody></table></div><textarea id="copyText"></textarea><hr><div id="selectBox"><ul><li class="fl" id="copySltMgnet"><a href="javascript:void(0)">複製磁鏈</a></li><li class="fl" id="copySltDL"><a href="javascript:void(0)">複製種子下载链接</a></li><li class="fl" id="selectAll" flag=false><a href="javascript:void(0)">全選</a></li><li class="fl" id="selectInvert"><a href="javascript:void(0)">反選</a></li><li class="fl" style="color:#666;line-height:28px">已選擇:<span id="selected">0</span>項</li><li class="fr" id="close"><a href="javascript:void(0)">關閉</a></li></ul></div>'
let sltObjs=['.nav_title .fl:last','.nav_title .fl:last','.nav_title .fl:last','.table.clear .nav_title:first'];
let addObjTxts=[goPage,filter,ExtractText,TextBox];
addObj(sltObjs,addObjTxts);
}
//扩展新番索引列表
function resourceTable(){
$('#mini_jmd>table:first-of-type').css('display','none');
$('#mini_jmd>table:last-of-type').removeAttr("style");
$('#mini_jmd>table:last-of-type').attr("class",'jmd');
$('#mini_jmd>table:last-of-type tr:even').addClass('even');
$('#mini_jmd>table:last-of-type tr:odd').addClass('odd');
let d=new Date();
let day=d.getDay();
console.log(day)
$('#mini_jmd>table:last tr:eq('+day+')').addClass('today');
}
//String转换为Boolean
function stringToBoolean(str){
switch(str.toLowerCase())
{
case "true": case "yes": case "1": return true;
case "false": case "no": case "0": case null: return false;
default: return Boolean(str);
}
}
//复制事件
function copy(str){
str=str.substring(0,str.length-1)
$('#copyText').val(str)
$('#copyText').select()
document.execCommand('copy');
}
//检测是否全选
function isSelectAll(){
if(Number($('#magnetBox #selected').text())==$('#magnetUrl [type="checkBox"]').length){
$('#selectAll').attr('flag',true)
}
else{
$('#selectAll').attr('flag',false)
}
}
//显示提取窗口
function show(){
$('#magnetBox').fadeIn(250)
let left=window.innerWidth/2-$('#magnetUrl')[0].offsetWidth/2;
let top=window.innerHeight*0.2;
$('#magnetBox').css({
'left':left,
'top':top
})
}
//隐藏提取窗口
function hide(){
$('#magnetBox').stop().fadeOut(200,()=>{
$('#magnetBox').removeAttr('style');
$('#magnetUrl tbody').text('')
});
}
//添加对象
function addObj(selectObjs,addObjTxts){
if(arguments.length>=3||arguments.length<=1){
throw 'addObj函数所传递的参数个数不对,请确保传递了两个参数';
return;
}
if(typeof arguments[0] == "object"){
if(arguments[0].length!=arguments[1].length){
throw 'addObj函数所传递的参数的长度不一致';
return;
}
}
if(typeof arguments[0] == "string"){
$(arguments[0]).after(arguments[1]);
}
else{
for(let i in selectObjs){
$(selectObjs[i]).after(addObjTxts[i]);
}
}
}