bilibili_search_recommendations.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. #!/usr/bin/env python3
  2. """
  3. B站搜索推荐词接口
  4. 获取B站平台搜索框中的推荐词
  5. """
  6. import requests
  7. import json
  8. import os
  9. import argparse
  10. from datetime import datetime
  11. from typing import Dict, Any
  12. import sys
  13. from pathlib import Path
  14. # 添加项目根目录到路径并导入配置
  15. sys.path.insert(0, str(Path(__file__).parent.parent.parent))
  16. from lib.config import get_data_dir
  17. class BilibiliSearchRecommendations:
  18. """B站搜索推荐词API封装类"""
  19. BASE_URL = "http://47.84.182.56:8001"
  20. TOOL_NAME = "Bilibili_Search_Recommendations"
  21. PLATFORM = "bilibili" # 平台名称
  22. def __init__(self, results_dir: str = None):
  23. """
  24. 初始化API客户端
  25. Args:
  26. results_dir: 结果输出目录,默认为项目根目录下的 data/search_recommendations 文件夹
  27. """
  28. self.api_url = f"{self.BASE_URL}/tools/call/{self.TOOL_NAME}"
  29. # 设置结果输出目录
  30. if results_dir:
  31. self.results_base_dir = results_dir
  32. else:
  33. # 默认从配置读取
  34. self.results_base_dir = get_data_dir("search_recommendations")
  35. def get_recommendations(self, keyword: str, timeout: int = 30) -> Dict[str, Any]:
  36. """
  37. 获取B站搜索推荐词
  38. Args:
  39. keyword: 搜索关键词
  40. timeout: 请求超时时间(秒),默认30秒
  41. Returns:
  42. API响应的JSON数据
  43. Raises:
  44. requests.exceptions.RequestException: 请求失败时抛出异常
  45. """
  46. payload = {
  47. "keyword": keyword
  48. }
  49. try:
  50. response = requests.post(
  51. self.api_url,
  52. json=payload,
  53. timeout=timeout,
  54. headers={"Content-Type": "application/json"}
  55. )
  56. response.raise_for_status()
  57. return response.json()
  58. except requests.exceptions.RequestException as e:
  59. print(f"请求失败: {e}")
  60. raise
  61. def save_result(self, keyword: str, result: Dict[str, Any]) -> str:
  62. """
  63. 保存结果到文件
  64. 目录结构: results/平台/关键词/时间戳.json
  65. Args:
  66. keyword: 搜索关键词
  67. result: API返回的结果
  68. Returns:
  69. 保存的文件路径
  70. """
  71. # 创建目录结构: results/平台/关键词/
  72. result_dir = os.path.join(self.results_base_dir, self.PLATFORM, keyword)
  73. os.makedirs(result_dir, exist_ok=True)
  74. # 文件名使用时间戳
  75. timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
  76. filename = f"{timestamp}.json"
  77. filepath = os.path.join(result_dir, filename)
  78. # 保存结果
  79. with open(filepath, 'w', encoding='utf-8') as f:
  80. json.dump(result, f, ensure_ascii=False, indent=2)
  81. return filepath
  82. def main():
  83. """示例使用"""
  84. # 解析命令行参数
  85. parser = argparse.ArgumentParser(description='B站搜索推荐词接口')
  86. parser.add_argument(
  87. '--results-dir',
  88. type=str,
  89. default=None,
  90. help='结果输出目录 (默认: 从配置读取)'
  91. )
  92. parser.add_argument(
  93. '--keyword',
  94. type=str,
  95. required=True,
  96. help='搜索关键词 (必填)'
  97. )
  98. args = parser.parse_args()
  99. # 创建API客户端实例
  100. client = BilibiliSearchRecommendations(results_dir=args.results_dir)
  101. # 获取推荐词并保存
  102. try:
  103. result = client.get_recommendations(args.keyword)
  104. filepath = client.save_result(args.keyword, result)
  105. print(f"Output: {filepath}")
  106. except Exception as e:
  107. print(f"Error: {e}", file=__import__('sys').stderr)
  108. if __name__ == "__main__":
  109. main()