YouTube Engagement Panel Text Extractor

提取并复制 ytd-engagement-panel-section-list-renderer 标签下的文本

当前为 2024-12-10 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name YouTube Engagement Panel Text Extractor
  3. // @namespace http://tampermonkey.net/
  4. // @version 0.5
  5. // @description 提取并复制 ytd-engagement-panel-section-list-renderer 标签下的文本
  6. // @author 微信:civilpy
  7. // @match https://www.youtube.com/*
  8. // @grant none
  9. // ==/UserScript==
  10.  
  11. (function() {
  12. 'use strict';
  13.  
  14. // 创建一个容器来保持两个按钮在一起
  15. const buttonContainer = document.createElement('div');
  16. buttonContainer.style.position = 'fixed';
  17. buttonContainer.style.top = '50%'; // 设置为页面高度的50%
  18. buttonContainer.style.right = '10px'; // 距离右侧10像素
  19. buttonContainer.style.transform = 'translateY(-50%)'; // 垂直居中对齐
  20. buttonContainer.style.display = 'flex';
  21. buttonContainer.style.flexDirection = 'column';
  22. buttonContainer.style.alignItems = 'flex-end'; // 将子元素靠右对齐
  23.  
  24. // 创建两个按钮
  25. const button1 = document.createElement('button');
  26. button1.innerText = '提取文字';
  27. button1.style.marginBottom = '10px'; // 给两个按钮之间添加一些间距
  28. const button2 = document.createElement('button');
  29. button2.innerText = '复制文字';
  30. button2.disabled = true; // 初始状态下禁用复制按钮
  31.  
  32. // 添加到容器
  33. buttonContainer.appendChild(button1);
  34. buttonContainer.appendChild(button2);
  35.  
  36. // 添加到页面
  37. document.body.appendChild(buttonContainer);
  38.  
  39. let extractedText = '';
  40.  
  41. button1.addEventListener('click', () => {
  42. // 查找所有ytd-engagement-panel-section-list-renderer元素并提取其文本内容
  43. const elements = document.querySelectorAll('ytd-engagement-panel-section-list-renderer');
  44. // 提取文本并去除前后空白,过滤掉空行或仅有空白字符的行
  45. extractedText = Array.from(elements)
  46. .map(el => el.textContent.trim()) // 去除每段文字前后的空白字符
  47. .filter(line => line.replace(/\s+/g, '').length > 0) // 使用正则表达式替换所有空白字符,并检查是否为空字符串
  48. .join('\n'); // 将所有非空行用换行符连接起来
  49.  
  50. console.log('已提取的文字:', extractedText); // 输出到控制台供调试
  51.  
  52. // 启用复制按钮
  53. button2.disabled = false;
  54. });
  55.  
  56. button2.addEventListener('click', () => {
  57. if (extractedText) {
  58. // 清洗文本,去掉空行
  59. const cleanedText = extractedText.split('\n').filter(line => line.trim() !== '').join('\n');
  60. // 获取当前时间戳
  61. const timestamp = new Date().toISOString().replace(/[:.]/g, '-'); // 替换非法文件名字符
  62.  
  63. // 创建文件内容
  64. const fileContent = "分析总结以下文本:\n" + extractedText;
  65.  
  66. // 创建隐藏的<a>元素用于下载
  67. const element = document.createElement('a');
  68. const blob = new Blob([fileContent], { type: 'text/plain' });
  69. const url = URL.createObjectURL(blob);
  70. element.href = url;
  71. element.download = `${timestamp}.txt`; // 设置文件名为时间戳.txt
  72.  
  73. // 将<a>元素添加到DOM中并触发点击事件
  74. document.body.appendChild(element);
  75. element.click();
  76.  
  77. // 清理
  78. document.body.removeChild(element);
  79. URL.revokeObjectURL(url);
  80.  
  81. console.log('文件已准备下载');
  82. alert('文件已准备下载');
  83. }
  84. });
  85. })();