Files
Esmart/xp/test.py
lychang 37af6c33ee init
2025-09-16 01:54:46 +08:00

285 lines
31 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# !/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)