285 lines
31 KiB
Python
285 lines
31 KiB
Python
# !/usr/bin/env python
|
||
# -*- coding:utf-8 -*-
|
||
|
||
import json
|
||
import time
|
||
|
||
import requests
|
||
|
||
|
||
class SmartTable:
|
||
def __init__(self, doc_id, sheet_id):
|
||
self.doc_id = doc_id
|
||
self.sheet_id = sheet_id
|
||
self._columns = None
|
||
self._data = None
|
||
|
||
@staticmethod
|
||
def _post(url, body):
|
||
resp = requests.post(url, json=body)
|
||
if resp.status_code == 200:
|
||
return resp.json()
|
||
return {}
|
||
|
||
def _get_columns(self):
|
||
url = "https://a.cmdp.cn/umss/v1/wxw/common/submit"
|
||
body = {
|
||
"url": "https://qyapi.weixin.qq.com/cgi-bin/wedoc/smartsheet/get_fields",
|
||
"method": "POST",
|
||
"body": {
|
||
"docid": self.doc_id,
|
||
"sheet_id": self.sheet_id
|
||
}
|
||
}
|
||
response = self._post(url, body)
|
||
if response:
|
||
fields = response["fields"]
|
||
return fields
|
||
return []
|
||
|
||
def _get_data(self, filters: dict, cursor: int = 0, limit: int = 1000):
|
||
url = "https://a.cmdp.cn/umss/v1/wxw/smartSheet/getRecords"
|
||
body = {
|
||
"docid": self.doc_id,
|
||
"sheet_id": self.sheet_id,
|
||
"filter_spec": filters,
|
||
"offset": cursor,
|
||
"limit": limit
|
||
}
|
||
response = self._post(url, body)
|
||
if response:
|
||
cursor = response["next"]
|
||
records = response["records"]
|
||
return cursor, records
|
||
return 0, []
|
||
|
||
def _add(self, records: list):
|
||
url = "https://a.cmdp.cn/umss/v1/wxw/smartSheet/addRecords"
|
||
body = {
|
||
"docid": self.doc_id,
|
||
"sheet_id": self.sheet_id,
|
||
"key_type": "CELL_VALUE_KEY_TYPE_FIELD_TITLE",
|
||
"records": records
|
||
}
|
||
response = self._post(url, body)
|
||
if response:
|
||
return True
|
||
return False
|
||
|
||
def _transform_data(self, data: dict):
|
||
result = {}
|
||
columns = self.columns
|
||
for i in data:
|
||
type_info = columns[i]
|
||
i_type = type_info.get("field_type")
|
||
if i_type == "FIELD_TYPE_TEXT":
|
||
result[i] = [
|
||
{
|
||
"format": {},
|
||
"text": data[i],
|
||
"type": "text"
|
||
}
|
||
]
|
||
elif i_type == "FIELD_TYPE_SINGLE_SELECT":
|
||
options = {i["text"]: i for i in type_info['property_single_select']["options"]}
|
||
result[i] = [
|
||
options[data[i]]
|
||
]
|
||
else:
|
||
result[i] = data[i]
|
||
return result
|
||
|
||
@property
|
||
def columns(self):
|
||
if self._columns is None:
|
||
self._columns = self._get_columns()
|
||
return {i["field_title"]: i for i in self._columns}
|
||
|
||
@property
|
||
def data(self):
|
||
if self._data is None:
|
||
self._data = self.search({})
|
||
return self._data
|
||
|
||
def search(self, filters: dict):
|
||
cursor = 0
|
||
result = []
|
||
while True:
|
||
cursor, records = self._get_data(filters, cursor=cursor)
|
||
result += records
|
||
if cursor == 0:
|
||
break
|
||
return result
|
||
|
||
def add(self, data: dict):
|
||
data = self._transform_data(data)
|
||
return self._add([{"values":data}])
|
||
|
||
|
||
class PushSmartMessage:
|
||
DOC_ID = "dc1zao6J8YnS9p86FKKvKQadukmFXlXv3dU1qVQrgcjB81zdSVI7qoi9a7K_OpN4BTyXc8EbYVXxpnQNUUTMWwIw"
|
||
USERS_SHEET_ID = "8vVxEx"
|
||
MESSAGE_SHEET_ID = "tFWMlM"
|
||
|
||
def __init__(self):
|
||
self.users_table = SmartTable(self.DOC_ID, self.USERS_SHEET_ID)
|
||
self.message_table = SmartTable(self.DOC_ID, self.MESSAGE_SHEET_ID)
|
||
|
||
@staticmethod
|
||
def _start_push_message() -> bool:
|
||
url = "https://cloud.cmdp.cn/wapi/recommend_message_push"
|
||
resp = requests.get(url)
|
||
if resp.status_code == 200:
|
||
return True
|
||
return False
|
||
|
||
def get_to_users(self, name: str, user_type: str = ""):
|
||
conditions = []
|
||
if user_type != "":
|
||
columns = self.users_table.columns
|
||
options = {i["text"]: i for i in columns["类型"]['property_single_select']["options"]}
|
||
conditions.append({
|
||
"field_id": "fabcde",
|
||
"field_type": "FIELD_TYPE_SINGLE_SELECT",
|
||
"operator": "OPERATOR_IS",
|
||
"string_value": {
|
||
"value": [
|
||
options[user_type]['id']
|
||
]
|
||
}
|
||
})
|
||
conditions.append({
|
||
"field_id": "fmTMGx",
|
||
"field_type": "FIELD_TYPE_SINGLE_SELECT",
|
||
"operator": "OPERATOR_CONTAINS",
|
||
"string_value": {
|
||
"value": [
|
||
name
|
||
]
|
||
}
|
||
})
|
||
|
||
return {i["record_id"]: i for i in self.users_table.search({
|
||
"conjunction": "CONJUNCTION_AND",
|
||
"conditions": conditions
|
||
})}
|
||
|
||
def _send(self, message: dict, to_users: list):
|
||
self.message_table.add({
|
||
"*栏目#gName": message["gName"],
|
||
"状态": "待发布",
|
||
"*摘要#subject": message["subject"],
|
||
"置顶#isTop": message["isTop"],
|
||
"*详情#content": message["content"],
|
||
"发布日期": time.strftime("%Y-%m-%d", time.localtime(time.time())),
|
||
"*标题#title": message["title"],
|
||
"*消息接收对象#sendList": to_users})
|
||
|
||
def send(self, message: dict, to: dict, processor=None):
|
||
name = to.get("name", "")
|
||
user_type = to.get("type", "")
|
||
ids = self.get_to_users(name, user_type)
|
||
if processor:
|
||
for i in ids:
|
||
_message = processor(message, i)
|
||
self._send(_message, [i])
|
||
else:
|
||
self._send(message, [i for i in ids])
|
||
self._start_push_message()
|
||
|
||
def send_batch(self, message, tos: list):
|
||
_tos = []
|
||
for to in tos:
|
||
_tos += self.get_to_users(to["name"], to["type"])
|
||
self._send(message, [i for i in _tos])
|
||
self._start_push_message()
|
||
|
||
st = PushSmartMessage()
|
||
|
||
def send_message(message:dict,to:dict):
|
||
url = "http://10.0.0.39/cloud/in/api/bulletin/release"
|
||
body = {
|
||
"typeCode": "recommend",
|
||
"releaseObjs": [
|
||
to
|
||
],
|
||
"bulletin": message
|
||
}
|
||
try:
|
||
resp = requests.post(url,json=body,timeout=30)
|
||
if resp.status_code == 200:
|
||
return resp.json()
|
||
else:
|
||
return resp.json()
|
||
except Exception as e:
|
||
print(e)
|
||
return {'data': '请求错误', 'code': 500, 'msg': 'error'}
|
||
|
||
|
||
def join_content(string:str):
|
||
return f"""
|
||
环境信披新规实施在即,我司基于775家上市公司的母公司和子公司数据,已完成环境信息跑批试点,为贵司提供部分省份的样例数据。同时,我司智填类信披填报产品已升级环境信披模块,可协助客户快速整合跨地域子公司全量环境数据、规避信披风险、生成相关报告。贵司若对此感兴趣,有意合作,可联系我司预约详谈。
|
||
|
||
---
|
||
|
||
{string}
|
||
|
||
---
|
||
|
||
致远速联公众号:genesysinfo_zysl
|
||
---
|
||
|
||
预约联系登记:
|
||
---
|
||
|
||
<img src="" alt="登记表"/>
|
||
|
||
---"""
|
||
|
||
def complete_parameters(security_code,company_name,content):
|
||
return {
|
||
"gName": "情报速递",
|
||
"subject": "环境信披新规实施在即,我司已完成部分环境信息跑批试点,为贵司提供部分样例数据。",
|
||
"isTop": True,
|
||
"content": content,
|
||
"title": f"[{company_name}({security_code})]环境信息依法披露情况(样例数据)"
|
||
}
|
||
|
||
|
||
if __name__ == '__main__':
|
||
with open("ui.json","r",encoding="utf-8") as f:
|
||
user_info = json.load(f)
|
||
company_list = {}
|
||
|
||
for i in user_info:
|
||
i_info = user_info[i]["values"]
|
||
name = i_info['名称#name'][0]["text"].split("_")[1]
|
||
eid = i_info['来源对象ID#eid'][0]["text"]
|
||
company_list[name] = eid
|
||
import pandas as pd
|
||
from time import sleep
|
||
df = pd.read_excel("result.xlsx",dtype="object")
|
||
send_data = []
|
||
for i in df.values:
|
||
sc = i[0]
|
||
cn = i[1]
|
||
ctype = i[3]
|
||
if "VIP" in ctype:
|
||
response = {'data': '跳过vip用户', 'code': 300, 'msg': 'skip'}
|
||
else:
|
||
md = join_content(i[4].replace("\n\n\n",""))
|
||
# message = complete_parameters(sc, cn, md)
|
||
#
|
||
# entity_id = company_list.get(sc)
|
||
# if entity_id is None:
|
||
# response = {'data': f'无法找到{sc}的eid', 'code': 400, 'msg': 'error'}
|
||
# else:
|
||
# # response = {'data': '可发送', 'code': 200, 'msg': 'success'}
|
||
# response = send_message(message, {"value":entity_id,"type":"company"})
|
||
# print(sc, "已发送")
|
||
# sleep(1)
|
||
# send_data.append([sc,cn,ctype,json.dumps(response,ensure_ascii=False)])
|
||
send_data.append([sc, cn, ctype, md])
|
||
send_set = pd.DataFrame(send_data,columns=["security_code","company_name","costom_type","content"])
|
||
send_set.to_excel("s.xlsx",index=False)
|