Greasy Fork is available in English.

单品分析_爆品指数_人群分析对比

云图扩展工具

// ==UserScript==
// @name         单品分析_爆品指数_人群分析对比
// @namespace    http://tampermonkey.net/
// @version      1.1.2
// @description  云图扩展工具
// @author       siji-Xian
// @match        *://yuntu.oceanengine.com/yuntu_brand/product/productOverview/productAnalysis/crowd*
// @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);

  const button = document.createElement("div");
  button.textContent = "导出画像";
  Object.assign(button.style, {
    height: "34px",
    lineHeight: "var(--line-height, 34px)",
    alignItems: "center",
    color: "#FFF",
    background: "linear-gradient(60deg, rgb(95, 240, 225), rgb(47, 132, 254))",
    borderRadius: "5px",
    marginLeft: "10px",
    fontSize: "13px",
    padding: "0 10px",
    cursor: "pointer",
    fontWeight: "500"
  });
  button.addEventListener("click", urlClick);

 //目标数据
 let target_data = null;
 let res_data = 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, 57) == "/product_node/v2/api/productAnalysis/productIndexPortrait"
     ) {
       target_data = JSON.parse(obj?.target?.response);
       res_data = JSON.parse(obj?.target?._data);
     }
   }
 })();

  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;
  }
    
  const objData = {
    BRAND: '本品',
    COMPETITOR_BRAND: '对比商品',
    INDUSTRY_BRAND: '行业Top20',
    ALL: '全部',
    LIVE_ROOM: '直播',
    PRODUCT_CARD: '商品卡',
    SHORT_VIDEO: '短视频',
    PURCHASE: '商品购买',
    CLICK: '商品点击',
    CLICK_NOT_PURCHASE: '商品后未购',
    SHOW: '商品曝光',
    SHOW_NOT_PURCHASE: '曝光后未购',
    ADD_CART: '商品加购'
  }
  

  //获取aadvid
  const aadvid = getQueryVariable("aadvid");

  //message.js
  let loadingMsg = null;

  function appendDoc() {
    const likeComment = document.querySelectorAll(".byted-radio-group-size-md")[3];
    if (likeComment) {
      likeComment.append(button);
      return;
    }
    setTimeout(appendDoc, 1000);
  }
  appendDoc();

  function formatData(data) {
    const result = [];
    data.items.forEach((item) => {
      const newItem = {
        labelName: data.name,
        name: item.name,
        value: item.value,
      };
      result.push(newItem);
    });
    return result;
  }

  async function getData(e) {
    loadingMsg = Qmsg.loading("正在导出,请勿重复点击!");

    const formatRes = (res) => {
      return res?.map((v) => {
          return formatData(v);
        })
        .flat();
    };
    const targetRes_formatted = formatRes(e?.data?.competitorData);
    const contrastRes_formatted = formatRes(e?.data?.selfData);

    const variables = res_data;
      expExcel([
      {
        label: `目标组A-${objData[variables.competitorDimension.benchmarkType]}-${objData[variables.competitorDimension.contentType]}-${objData[variables.competitorDimension.actionType]}`,
        value: targetRes_formatted,
      },
      {
        label: `目标组B-${objData[variables.selfDimension.benchmarkType]}-${objData[variables.selfDimension.contentType]}-${objData[variables.selfDimension.actionType]}`,
        value: contrastRes_formatted,
      },
    ]);
  }

  function expExcel(e) {
    let contrast = {
      标签类型: "labelName",
      标签: "name",
      占比: "value"
    };
    let fileName =
      document.querySelector(".byted-input-size-md").value || "data";
    let option = {};
    option.fileName = fileName; //文件名
    option.datas = e.map((v) => {
      return {
        sheetName: v.label,
        sheetData: v.value,
        sheetHeader: Object.keys(contrast),
        sheetFilter: Object.values(contrast),
        columnWidths: [], // 列宽
      };
    });
    var toExcel = new ExportJsonExcel(option);
    toExcel.saveExcel();
    setTimeout(() => {
      loadingMsg.close();
    }, 1000);
  }

  function urlClick() {
    if (target_data) {
      loadingMsg = Qmsg.loading("正在导出,请勿重复点击!");
      getData(target_data);
    } else {
      loadingMsg = Qmsg.error("数据加载失败,请重试");
    }
  }
})();