// ==UserScript== // @name 导出最新世界羽联排名 // @namespace https://weibo.com/guoxuebiji/profile?is_all=1 // @version 1.0 // @description 导出最新世界羽联排名(https://www.badmintoncn.com/ranking.php?type=6) // @author 东风 // @date 2021-10-25 // @modified 2021-10-25 // @match https://www.badmintoncn.com/ranking.php?type=* // @license BSD 3-Clause License // @grant unsafeWindow // @grant GM_setClipboard // @grant GM_info // @grant GM_download // @grant GM_registerMenuCommand // @grant GM_xmlhttpRequest // @grant GM.xmlHttpRequest // @grant GM_openInTab // @grant GM.openInTab // @grant GM_getValue // @grant GM.getValue // @grant GM_setValue // @grant GM.setValue // @downloadURL https://update.greasyfork.icu/scripts/434500/%E5%AF%BC%E5%87%BA%E6%9C%80%E6%96%B0%E4%B8%96%E7%95%8C%E7%BE%BD%E8%81%94%E6%8E%92%E5%90%8D.user.js // @updateURL https://update.greasyfork.icu/scripts/434500/%E5%AF%BC%E5%87%BA%E6%9C%80%E6%96%B0%E4%B8%96%E7%95%8C%E7%BE%BD%E8%81%94%E6%8E%92%E5%90%8D.meta.js // ==/UserScript== (function () { 'use strict'; //==========utils===================================================================== //加载css文件 function addCSS(href) { var link = document.createElement('link'); link.type = 'text/css'; link.rel = 'stylesheet'; link.href = href; document.getElementsByTagName("head")[0].appendChild(link); } //加载js文件 function addJS(src, cb, onerror ) { var script = document.createElement("script"); script.type = "text/javascript"; script.src = src; console.log("addJS",script) document.getElementsByTagName('head')[0].appendChild(script); script.onload = typeof cb === "function" ? cb : function () {}; script.onerror = typeof onerror === "function" ? onerror : function () {}; } // 加载css字符串 function GMaddStyleString(css) { var myStyle = document.createElement('style'); myStyle.textContent = css; var doc = document.head || document.documentElement; doc.appendChild(myStyle); } function AddHtml(html) { document.body.insertAdjacentHTML('afterEnd', html); } // 改用ZUI //https://www.openzui.com/ addJS("https://libs.baidu.com/jquery/2.0.0/jquery.min.js", function () { console.log("-------------------load jq-------------------") window.$ = $.noConflict(); // addCSS("https://cdn.bootcdn.net/ajax/libs/zui/1.9.2/css/zui.min.css"); // addJS("https://cdn.bootcdn.net/ajax/libs/zui/1.9.2/js/zui.min.js", function () { // addCSS("https://lib.baomitu.com/zui/1.9.2/css/zui.min.css"); // addJS("https://lib.baomitu.com/zui/1.9.2/js/zui.min.js", function () { // console.log("-------------------load bootcdn zui.min.js-------------------") // }) addJS("https://lib.baomitu.com/xlsx/0.17.0/xlsx.full.min.js"); }); function GetFileName(url) { var Business=url.split("/"); return Business[Business.length-1]; } // String.prototype.TextFilter=function(){ // var pattern=new RegExp("[`~%!@#^=''?~!@#¥……&——‘”“'?*()(),,。.、]"); //[]内输入你要过滤的字符 // var rs=""; // for(var i=0;i= 0) { title = title.substring(0,n); } return title; } function ShowTips(str) { new $.zui.Messager(str, { type: 'success', // 定义颜色主题 time:2000 }).show(); } function ShowDialog(str) { // (new $.zui.ModalTrigger({custom: str})).show(); // console.log("ShowDialog"+str) alert(str) } //字符串是否包含子串 function isContains(str, substr) { //str是否包含substr return str.indexOf(substr) >= 0; } // 把网页获取的对象转换成数组 function objToArray(x) { var list = []; console.log(x) for (var i = 0; i < x.length; i++) { list[i] = x[i]; } return list } // 补零 function PrefixZero(num, n) { return (Array(n).join(0) + num).slice(-n); } // 文件加前缀 function AddPreFilename(fileName, index, max) { var len = (max+"").length return "P"+PrefixZero(index,len)+"."+fileName } function WebGet(url, success) { jQuery.ajax({ url: url, async: false, success: success, omplete: function (data) { if (data.status === 200) { } else { ShowTips("系统错误:暂时无法连接服务器") } } }); } function DownloadTxt(text, fileType, fileName) { var blob = new Blob([text], { type: fileType }); var a = document.createElement('a'); a.download = fileName; a.href = URL.createObjectURL(blob); a.dataset.downloadurl = [fileType, a.download, a.href].join(':'); a.style.display = "none"; document.body.appendChild(a); a.click(); document.body.removeChild(a); setTimeout(function() { URL.revokeObjectURL(a.href); }, 1500); } // csv转sheet对象 function csv2sheet(csv) { var sheet = {}; // 将要生成的sheet csv = csv.split('\n'); csv.forEach(function(row, i) { console.log(row, i) row = row.split(','); if(i == 0) sheet['!ref'] = 'A1:'+String.fromCharCode(65+row.length-1)+(csv.length-1); row.forEach(function(col, j) { sheet[String.fromCharCode(65+j)+(i+1)] = {v: col}; }); }); return sheet; } // 将一个sheet转成最终的excel文件的blob对象,然后利用URL.createObjectURL下载 function sheet2blob(sheet, sheetName) { sheetName = sheetName || 'sheet1'; var workbook = { SheetNames: [sheetName], Sheets: {} }; workbook.Sheets[sheetName] = sheet; // 生成excel的配置项 var wopts = { bookType: 'xlsx', // 要生成的文件类型 bookSST: false, // 是否生成Shared String Table,官方解释是,如果开启生成速度会下降,但在低版本IOS设备上有更好的兼容性 type: 'binary' }; var wbout = XLSX.write(workbook, wopts); var blob = new Blob([s2ab(wbout)], {type:"application/octet-stream"}); // 字符串转ArrayBuffer function s2ab(s) { var buf = new ArrayBuffer(s.length); var view = new Uint8Array(buf); for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF; return buf; } return blob; } /** * 通用的打开下载对话框方法,没有测试过具体兼容性 * @param url 下载地址,也可以是一个blob对象,必选 * @param saveName 保存文件名,可选 */ function openDownloadDialog(url, saveName) { if(typeof url == 'object' && url instanceof Blob) { url = URL.createObjectURL(url); // 创建blob地址 } var aLink = document.createElement('a'); aLink.href = url; aLink.download = saveName || ''; // HTML5新增的属性,指定保存文件名,可以不要后缀,注意,file:///模式下不会生效 var event; if(window.MouseEvent) event = new MouseEvent('click'); else { event = document.createEvent('MouseEvents'); event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null); } aLink.dispatchEvent(event); } // 传入csv,执行后就会弹出下载框 function exportExcel(csv) { var sheet = csv2sheet(csv); var blob = sheet2blob(sheet); openDownloadDialog(blob, '导出.xlsx') } //=============================================================================== function Table2Array(d) { var ranktable = d.getElementsByClassName("ranktable")[0].children[0].children // console.log("ranktable = ", ranktable) var table = [["排名","国家/地区","球员","升/降","积分"]] for (var i = 1; i < ranktable.length; i++) { var arr = [] var item = ranktable[i].getElementsByTagName("td"); // console.log(i, item) // 获取队员名字 var players = item[2].getElementsByClassName("player") var str = "" for (var index = 0; index < players.length; index++) { if (index > 0) {str = str + "/"} str = str + players[index].innerText.replace(/\n+/g," ") } arr[0] = parseInt(item[0].innerText)//排名 arr[1] = item[1].getElementsByClassName("country")[0].innerText//国家 arr[2] = str //运动员 arr[3] = parseInt(item[3].innerText)?parseInt(item[3].innerText):""//排名变化 // arr[4] = parseInt(item[4].innerText)//积分 if (item[3].getElementsByTagName("img").length>0) { var src = item[3].getElementsByTagName("img")[0].src if (isContains(src, "arrow-down.png")) { arr[3] = -arr[3] //排名下降 } } table[i] = arr // console.log(item, item.getElementsByTagName("td")) } // console.log(table) return table } function ParseUrl() { // var table = Table2Array(document) // console.log(table) // if (true) {return} var names = ["男子单打","女子单打","男子双打","女子双打","混合双打"] var workbook = { SheetNames: names, Sheets: {} }; function DownloadHtml(url, sheetName) { WebGet(url, function(res){ // var sheetName = names[6-i] console.log("加载网页", sheetName) // console.log(res) var doc = (new DOMParser()).parseFromString(res, "text/html") // console.log(doc) var table = Table2Array(doc) workbook.Sheets[sheetName] = XLSX.utils.aoa_to_sheet(table);; }) } for (var i = 6; i <= 10; i++) { DownloadHtml("https://www.badmintoncn.com/ranking.php?type="+i, names[i-6]) } // 生成excel的配置项 var wopts = { bookType: 'xlsx', // 要生成的文件类型 bookSST: false, // 是否生成Shared String Table,官方解释是,如果开启生成速度会下降,但在低版本IOS设备上有更好的兼容性 type: 'binary' }; var wbout = XLSX.write(workbook, wopts); var blob = new Blob([s2ab(wbout)], {type:"application/octet-stream"}); // 字符串转ArrayBuffer function s2ab(s) { var buf = new ArrayBuffer(s.length); var view = new Uint8Array(buf); for (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF; return buf; } var filename = document.getElementsByClassName("title")[0].innerText openDownloadDialog(blob, filename+'.xlsx'); // var aoa = [ // ['主要信息', null, null, '其它信息'], // 特别注意合并的地方后面预留2个null // ['姓名', '性别', '年龄', '注册时间'], // ['张三', '男', 18, 1], // ['李四', '女', 22, 1] // ]; // var sheet = XLSX.utils.aoa_to_sheet(aoa); // sheet['!merges'] = [ // // 设置A1-C1的单元格合并 // {s: {r: 0, c: 0}, e: {r: 0, c: 2}} // ]; // openDownloadDialog(sheet2blob(sheet), '单元格合并示例.xlsx'); } var isInit = 0; function DoInit() { // isInit ++; // if (isInit != 2 ) {return} // console.log("----------------DoInit-------------") var btn = document.getElementsByClassName("btnDownload") if (btn.length > 0) { return } GMaddStyleString(`#download_movie_box {cursor:pointer; position:fixed; top:` + 60 + `px; left:` + 0 + `px; width:0px; background-color:#2E9AFE; z-index:2147483647; font-size:20px; text-align:left;} #download_movie_box .item_text {width:28px; padding:4px 0px; text-align:center;} #download_movie_box .item_text img {width:35px; height:35px; display:inline-block; vertical-align:middle;} `); // var $ = $ || window.$; var ImgBase64Data = "" var html = `
`; document.body.insertAdjacentHTML('afterEnd', html); document.getElementById("downloadVideos").onclick = function () { var urls = ParseUrl(); // console.log("urls = ",urls) // if (urls) { // Download(urls) // } }; } /* 主入口,分出不同模块:用户、画板,监听并刷新URL */ window.onload =function() { DoInit() } // GM_setValue("mytset","mytset---------------------------") // console.log(GM_getValue("mytset")) })();