云图扩展工具
- // ==UserScript==
- // @name 商品_细分市场_商品洞察_商品价位段分析
- // @namespace http://tampermonkey.net/
- // @version 1.1
- // @description 云图扩展工具
- // @author siji-Xian
- // @match *://yuntu.oceanengine.com/yuntu_brand/product/segmentedMarketList?*
- // @icon https://lf3-static.bytednsdoc.com/obj/eden-cn/prhaeh7pxvhn/yuntu/yuntu-logo_default.svg
- // @grant none
- // @license MIT
- // @require https://lf26-cdn-tos.bytecdntp.com/cdn/expire-1-M/jquery/3.2.1/jquery.min.js
- // @require https://cdn.bootcss.com/moment.js/2.20.1/moment.min.js
- // @require https://greasyfork.org/scripts/404478-jsonexportexcel-min/code/JsonExportExcelmin.js?version=811266
- // @require https://greasyfork.org/scripts/455576-qmsg/code/Qmsg.js?version=1122361
- // ==/UserScript==
- (function () {
- "use strict";
- var new_element = document.createElement("link");
- new_element.setAttribute("rel", "stylesheet");
- new_element.setAttribute("href", "https://qmsg.refrain.xyz/message.min.css");
- document.body.appendChild(new_element);
- let button = document.createElement("button"); //创建一个按钮
- button.textContent = "导出数据(商品洞察)";
- Object.assign(button.style, {
- height: "34px",
- lineHeight: "34px",
- alignItems: "center",
- color: "white",
- border: "none",
- background: "linear-gradient(90deg, rgba(0, 239, 253), rgba(64, 166, 254))",
- borderRadius: "5px",
- marginLeft: "10px",
- fontSize: "13px",
- padding: "0 10px",
- cursor: "pointer",
- fontWeight: "500",
- });
- button.addEventListener("click", urlClick); //监听按钮点击事件
- const getRequestOptions = {
- method: "GET",
- redirect: "follow",
- };
- //获取brand信息
- let brand = localStorage.getItem("__Garfish__platform__yuntu_user") || "";
- let brands = JSON.parse(brand);
- //获取industry_id
- let industry_id = null;
- (function listen() {
- var origin = {
- open: XMLHttpRequest.prototype.open,
- send: XMLHttpRequest.prototype.send,
- };
- XMLHttpRequest.prototype.open = function (a, b) {
- this.addEventListener("load", replaceFn);
- origin.open.apply(this, arguments);
- };
- XMLHttpRequest.prototype.send = function (a, b) {
- origin.send.apply(this, arguments);
- };
- function replaceFn(obj) {
- if (
- this?._url?.slice(0, 42) == "/yuntu_ng/api/v1/get_brand_competitor_list"
- ) {
- industry_id = JSON.parse(obj?.target?.response).data[0].industry_id;
- }
- }
- })();
- function getQueryVariable(variable) {
- var query = window.location.search.substring(1);
- var vars = query.split("&");
- for (var i = 0; i < vars.length; i++) {
- var pair = vars[i].split("=");
- if (pair[0] == variable) {
- return pair[1];
- }
- }
- return false;
- }
- //message.js
- let loadingMsg = null;
- function appendDoc() {
- setTimeout(() => {
- var like_comment = document.querySelectorAll(
- ".ReportListHeader__ButtonContainer-hbhHEO.fLMUtj"
- )[0];
- if (like_comment) {
- like_comment.append(button); //把按钮加入到 x 的子节点中
- return;
- }
- appendDoc();
- }, 1000);
- }
- appendDoc();
- let myHeaders = new Headers();
- myHeaders.append("content-type", "application/json");
- function fetchFun(url, data, requestOptions = getRequestOptions) {
- const urlData = Object.keys(data)
- .map((v) => `${v}=${data[v]}`)
- .join("&");
- return fetch(`${url}?${urlData}`, requestOptions)
- .then((response) => response.text())
- .then((r###lt) => {
- return JSON.parse(r###lt);
- })
- .catch((error) => console.log("error", error));
- }
- async function task_list(startPage, endPage) {
- loadingMsg = Qmsg.loading("正在导出,请勿重复点击!");
- let page = +(startPage);
- let pageSize = +((endPage + 1 - +startPage) * 10);
- let search_word = document.querySelector(".byted-input.byted-input-size-md")?.value
- let raw = JSON.stringify({
- "ids": [],
- page,
- pageSize,
- "keyword": search_word
- });
- let data = {
- aadvid: getQueryVariable("aadvid"),
- };
- let postRequestOptions = {
- method: "POST",
- headers: myHeaders,
- body: raw,
- redirect: "follow",
- };
- let taskList = await fetchFun(
- "/product_node/v2/api/segmentedMarket/reportList",
- data,
- postRequestOptions
- );
- let res = taskList?.data?.list
- ?.map((v) => {
- return { name: v.name, reportId: v.reportId, endTime:v.endTime, status:v.status ,periodType:v.periodType };
- })
- .filter((v) => v.status == "COMPLETED");
- let expExcelData = await Promise.all(
- res.map((v) => {
- let data = getData(v);
- return data;
- })
- );
- expExcel(expExcelData, startPage, endPage);
- expExcelData = [];
- }
- //数据获取
- async function getData(e) {
- let raw = JSON.stringify({
- "reportId": e.reportId,
- "categoryId": "0",
- "contentType": "ALL",
- "startDate": "0",
- "endDate": e.endTime,
- "dateType": e.periodType,
- "analysisType": "DRILL_DOWN",
- "itemType": "PRICE_SEGMENT"
- });
- let postRequestOptions = {
- method: "POST",
- headers: myHeaders,
- body: raw,
- redirect: "follow",
- };
- let data = {
- aadvid: getQueryVariable("aadvid"),
- };
- let requestData = await fetchFun(
- "https://yuntu.oceanengine.com/product_node/v2/api/industry/insightCategoryStats",
- data,
- postRequestOptions
- );
- let res = requestData.data.map(v=>{
- return {
- item:v.item,
- salesAmount: v.data?.salesAmount?.value,
- salesVolune: v.data?.salesVolune?.value,
- purchaseUidCnt: v.data?.purchaseUidCnt?.value,
- productCnt: v.data?.productCnt?.value,
- productAvgPrice: v.data?.productAvgPrice?.value,
- perUidOrderCnt: v.data?.perUidOrderCnt?.value,
- perUidPurchaseProductCnt: v.data?.perUidPurchaseProductCnt?.value,
- }
- }).filter(v=>{
- return v.item !== "0"
- })
- return {key:e.name,value:res}
- }
- function expExcel(e, startPage, endPage) {
- let contrast = {
- "商品关键词名称": "item",
- "销售金额(指数)": "salesAmount",
- "销售量(指数)": "salesVolune",
- "购买人数(指数)": "purchaseUidCnt",
- "商品数量(指数)": "productCnt"
- };
- let fileName = `细分市场报告商品洞察(${startPage}-${endPage}页)`;
- let option = {};
- option.fileName = fileName; //文件名
- option.datas = e?.map(v=>{
- return {
- sheetName: v.key,
- sheetData: v.value.length ? v.value : [{}],
- sheetHeader: Object.keys(contrast),
- sheetFilter: Object.values(contrast),
- columnWidths: [], // 列宽
- }
- });
- var toExcel = new ExportJsonExcel(option);
- toExcel.saveExcel();
- setTimeout(() => {
- loadingMsg.close();
- }, 1000);
- }
- function urlClick() {
- try {
- let res = prompt("页码,例: 1,2 (起始页和结束页中间用英文逗号分隔)");
- if (res) {
- let [startPage, endPage] = res.split(",");
- startPage = parseInt(startPage);
- endPage = parseInt(endPage);
- if (isNaN(startPage) || isNaN(endPage) || endPage < startPage) {
- throw new Error("页码格式错误!");
- }
- task_list(startPage, endPage);
- }
- } catch (err) {
- Qmsg.error(err.message);
- }
- }
- })();