feishu_form.py 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. # -*- coding: utf-8 -*-
  2. import json
  3. import os
  4. import sys
  5. from utils.feishu_utils import Feishu
  6. sys.path.append(os.getcwd())
  7. class Material():
  8. """
  9. 获取品类对应负责人任务明细
  10. """
  11. @classmethod
  12. def get_carry_data(cls, dt, FS_SHEET,NAME):
  13. data = Feishu.get_values_batch( "Wj0TsRKc0hZrHQtmtg4cZZIwn0c", FS_SHEET )
  14. processed_list = []
  15. try:
  16. for row in data[2:]:
  17. activate_data = row[4] # 启动日期
  18. if not activate_data:
  19. continue
  20. if int(activate_data) != int(dt):
  21. continue
  22. channel_mark = row[0]
  23. pq_ids = row[2]
  24. pq_label = row[3] # 站内标签
  25. video_url = row[5]
  26. title_category = row[6] #标题类别
  27. tag_transport_channel = row[7] # 搬运平台
  28. tag_transport_scene = row[8] # 搬运场景
  29. tag_transport_keyword = row[9] # 关键词
  30. tag = row[10] # 标签
  31. transform_rule = row[11] # 改造规则
  32. video_share = row[12] # 片中分享
  33. trailer_share = row[13] # 片尾分享
  34. trailer_share_audio = row[14] # 片尾分享声音
  35. video_clipping = row[15] # 剪裁
  36. video_clipping_time = row[16] # 秒数剪裁
  37. title_transform = row[17] # 标题改造
  38. number_dict = {
  39. "channel_mark": channel_mark,
  40. "name":NAME,
  41. "pq_ids": pq_ids,
  42. "pq_label": pq_label,
  43. "activate_data": activate_data,
  44. "video_url": video_url,
  45. "title_category": title_category,
  46. "tag_transport_channel": tag_transport_channel,
  47. "tag_transport_scene": tag_transport_scene,
  48. "tag_transport_keyword": tag_transport_keyword,
  49. "tag": tag,
  50. "transform_rule": transform_rule,
  51. "video_share": video_share,
  52. "trailer_share": trailer_share,
  53. "trailer_share_audio": trailer_share_audio,
  54. "video_clipping": video_clipping,
  55. "video_clipping_time": video_clipping_time,
  56. "title_transform": title_transform,
  57. "dt":dt
  58. }
  59. processed_list.append(json.dumps(number_dict, ensure_ascii=False))
  60. return processed_list
  61. except:
  62. return processed_list
  63. @classmethod
  64. def get_propmt_data(cls, trailer_share):
  65. try:
  66. if "AI片尾引导" not in trailer_share:
  67. trailer_share = "AI片尾引导"
  68. data = Feishu.get_values_batch( "Wj0TsRKc0hZrHQtmtg4cZZIwn0c", "Yxg7EK" )
  69. for row in data[1:]:
  70. name = row[0]
  71. if trailer_share == name:
  72. return row[1]
  73. return
  74. except:
  75. return None