🏠 Home 

杏坛豆瓣书籍自动检索工具

已有的书籍名称通过豆瓣API获取信息,然后填充至各个信息区


安装此脚本?
// ==UserScript==
// @name         杏坛豆瓣书籍自动检索工具
// @namespace    zhoubanxian
// @version      4.1
// @description  已有的书籍名称通过豆瓣API获取信息,然后填充至各个信息区
// @author       周半仙
// @match        https://xingtan.one/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=xingtan.one
// @grant        unsafeWindow
// @grant        GM_xmlhttpRequest
// @grant        GM_download
// @grant        GM_setValue
// @grant        GM_getValue
// ==/UserScript==
(function () {
'use strict';
// 获取当前页面的链接
var currentUrl = window.location.href;
// 判断链接是否包含 "details.php"
if (currentUrl.includes("details.php")) {
// 匹配给定的 XPath 表达式
var xpathExpression = '/html/body/table[2]/tbody/tr[2]/td/div/font/table[1]/tbody/tr[1]/td[2]/a[1]';
var r###lt = document.evaluate(xpathExpression, document, null, XPathR###lt.FIRST_ORDERED_NODE_TYPE, null);
// 获取匹配的元素
var element = r###lt.singleNodeValue;
if (element) {
// 获取元素的文本内容
var text = element.textContent;
// 提取倒数第二个 `.` 到倒数第三个 `.` 之间的内容
var regex = /(?:\.[^.]+)(\.)([^.]+)(?:\.[^.]+)$/; // 正则表达式
var match = regex.exec(text);
if (match && match[2]) {
var extractedText = match[2];
// 匹配给定的 XPath 表达式
var xpathExpression = '/html/body/table[2]/tbody/tr[2]/td/div/font/table[1]/tbody/tr[4]/td[2]/a[2]';
var r###lt = document.evaluate(xpathExpression, document, null, XPathR###lt.FIRST_ORDERED_NODE_TYPE, null);
// 获取匹配的链接元素
var linkElement = r###lt.singleNodeValue;
if (linkElement) {
// 获取链接的 href 属性值
var link = linkElement.getAttribute('href');
// 在链接后面追加参数
var updatedLink = link + '&type='+extractedText;
// 更新链接的 href 属性
linkElement.setAttribute('href', updatedLink);
}
}
}
}
// 判断链接是否包含 "edit.php",判断是否是编辑页面
if (currentUrl.includes("edit.php")) {
const xtXpath = "/html/body/table[2]/tbody/tr[2]/td/div/div[2]";
// 获取目标元素
const targetElement = document.evaluate(xtXpath, document, null, XPathR###lt.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
// 创建并插入<div>元素
const divElement = document.createElement('div');
targetElement.parentNode.insertBefore(divElement, targetElement.nextSibling);
divElement.style = 'width:58%;background-color:#f1939c;font-size:15px'
// 获取编辑页面标题的值
const titleXpath = "/html/body/table[2]/tbody/tr[2]/td/div/form/font/font/b/table/tbody/tr[2]/td[2]/input";
// 使用XPath获取元素
const element = document.evaluate(titleXpath, document, null, XPathR###lt.FIRST_ORDERED_NODE_TYPE, null).singleNodeValue;
// 检查元素是否存在并输出值
if (element) {
if (document.querySelector('input[name="autor"]').value != '本资源由LM-AUTO-BOT机器人自动发布,请及时修改资料') {
divElement.innerHTML += '当前种子已被编辑过,不再执行自动检索脚本....<br>';
return 0
}
// console.log("获取到标题是: ", element.value);
divElement.innerHTML += '温馨提示:<br>请<a style="color:red" href="https://xingtan.one/forums.php?action=viewtopic&forumid=23&topicid=43" target="\_blank">点击此处</a>了解完整的编辑规则后再使用脚本<br>否则只是给审核人员添加负担' + '<br><hr>';
divElement.innerHTML += '开始搜索:' + '<br>';
const url = `https://api.douban.com/v2/book/search?q=${encodeURIComponent(element.value)}&apikey=0ac44ae016490db2204ce0a042db2916`;
var values = [];
GM_xmlhttpRequest({
method: "GET",
url: url,
onload: function (response) {
var data = JSON.parse(response.responseText); // 解析返回值为JSON格式
var books = data.books; // 获取books数据数组
localStorage.setItem('books', JSON.stringify(books));
if(books.length == 0){
divElement.innerHTML += '暂未检索到相关资源' + '<br>';
}
// 循环遍历books数据,只显示前五条,然后自动匹配
for (var i = 0; i < 8; i++) {
var book = books[i]; // 获取当前书籍数据
var author = ''; // 获取作者
for (var j = 0; j < book.author.length; j++) {
author += book.author[j] +'&';
}
author = author.slice(0, -1);
var pubdate = book.pubdate.split('-')[0]; // 获取出版年份
var publisher = book.publisher; // 获取出版社
var value = "\n"
if (author) {
value += "作者: " + author + "\n";
}
if (publisher) {
value += "出版社: " + publisher + "\n";
}
if (book.subtitle) {
value += "副标题: " + book.subtitle + "\n";
}
if (pubdate) {
value += "出版年: " + pubdate + "\n";
}
if (book.pages) {
value += "页数: " + book.pages + "\n";
}
if (book.price) {
value += "定价: " + book.price + "\n";
}
if (book.binding) {
value += "装帧: " + book.binding + "\n";
}
if (book.isbn13) {
value += "ISBN: " + book.isbn13 + "\n\n";
}
if (book.summary) {
value += "内容简介: \n    " + book.summary + "\n\n";
}
if (book.author_intro) {
value += "作者简介: \n    " + book.author_intro + "\n";
}
values.push(value)
divElement.innerHTML += '<a style="color:yellow" onclick="insert(' + i +')">填充对应信息</a><a style="color:green" target="\_blank" href=' + "https://book.douban.com/subject/" + book.id + '>第' + (i + 1) + "条:" + book.title + '[查看对应书籍]</a><br>';
}
localStorage.setItem('values', JSON.stringify(values));
// 备用手动检索模式
// for (var i = 0; i < 5; i++) {
//     var book = books[i]; // 获取当前书籍数据
//     var author = book.author[0]; // 获取作者
//     var pubdate = book.pubdate.split('-')[0]; // 获取出版年份
//     var publisher = book.publisher; // 获取出版社
//     var r###lt = "作者:" + author +"/" + publisher +"/" + pubdate +"【对应格式】";
//     console.log(book.title)
//     console.log(r###lt); // 输出拼接后的结果
//     console.log("https://book.douban.com/subject/"+book.id) //输出豆瓣连接
// }
},
onerror: function (error) {
}
});
} else {
console.log("找不到元素");
}
}
// 创建一个 <script> 元素
var script = document.createElement('script');
// 定义要插入的函数
script.textContent = `
function insert(id,value) {
var urlString = window.location.href;
// 创建 URL 对象
var url = new URL(urlString);
// 获取链接中的 type 参数的值
var type = url.searchParams.get('type');
book = JSON.parse(localStorage.getItem('books'))[id];
var author = ''; // 获取作者
for (var j = 0; j < book.author.length; j++) {
author += book.author[j] +'&';
}
author = author.slice(0, -1);
var pubdate = book.pubdate.split('-')[0]; // 获取出版年份
var publisher = book.publisher; // 获取出版社
var small_descr = "作者:" + author +"/" + publisher +"/" + pubdate +"【"+type+"】";
var pic_url = ""
values = JSON.parse(localStorage.getItem('values'))[id]
alert("请等待一会,其中图片自动上传比较慢")
uploadImg("https://images.weserv.nl/?url=" + book.images.large).then(imageUrl => {
pic_url = imageUrl
values = JSON.parse(localStorage.getItem('values'))[id]
values = "[img]"+pic_url+"["+"/"+"img]"+ values;
document.querySelector('textarea[name="descr"]').value = values;
}).catch(error => {
console.error('图片上传或处理过程中发生错误:', error);
document.querySelector('textarea[name="descr"]').value = values;
});
document.querySelector('input[name="autor"]').value =author?author:"作者信息未获取";
document.querySelector('input[name="publisher"]').value = publisher?publisher:"出版社信息未获取";
document.querySelector('input[name="year"]').value = pubdate?pubdate:"年份信息未获取";
document.querySelector('input[name="ftype"]').value = "请自行填写";
document.querySelector('input[name="isbn"]').value = book.isbn13?book.isbn13:"无";
document.querySelector('input[name="pt_gen"]').value = "https://book.douban.com/subject/" + book.id;
}
function uploadImg(imageUrl){
return fetch(imageUrl) // 返回一个Promise
.then(response => response.blob())
.then(blob => {
const formData = new FormData();
formData.append('file', blob, 'image.jpg');
return fetch('https://img.xingtan.one/api/v1/upload', { // 注意这里也返回Promise
method: 'POST',
body: formData,
});
})
.then(response => response.json())
.then(data => {
if (data.status) {
const imageUrl = data.data.links.url;
console.log('图片上传成功,URL:', imageUrl);
return imageUrl; // 返回图片URL
} else {
throw new Error('图片上传失败: ' + data.message); // 抛出错误以便在外部捕获
}
})
.catch(error => {
console.error('图片上传过程中发生错误:', error);
throw error; // 重新抛出错误以便在外部捕获
});
}
`;
// 将 <script> 元素插入到页面的 <head> 元素中
document.head.appendChild(script);
})();