-
-
Notifications
You must be signed in to change notification settings - Fork 2
/
UPDATE_RECORD.py
55 lines (45 loc) · 1.93 KB
/
UPDATE_RECORD.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
import requests
import configparser
import json
import argparse
def UPDATE_RECORD(app_token=None, table_id=None, record_id=None, fields=None, config_file=None):
if config_file is None:
config_file = 'feishu-config.ini'
# 读取配置文件
config = configparser.ConfigParser()
config.read(config_file, encoding='utf-8')
# 如果参数为空,则使用配置文件中的默认值
if not app_token:
app_token = config.get('TOKEN', 'app_token')
if not table_id:
table_id = config.get('ID', 'table_id')
if not record_id:
record_id = config.get('ID', 'record_id')
user_access_token = config.get('TOKEN', 'user_access_token')
# 构造请求URL和头部
url = f"https://open.feishu.cn/open-apis/bitable/v1/apps/{app_token}/tables/{table_id}/records/{record_id}"
headers = {
'Authorization': f'Bearer {user_access_token}',
'Content-Type': 'application/json; charset=utf-8'
}
# 构造请求体
data = {
"fields": fields
}
# 发起请求,并返回响应体的json形式
response = requests.put(url, headers=headers, data=json.dumps(data))
return response.json()
def UPDATE_RECORD_CMD():
# 解析命令行参数
parser = argparse.ArgumentParser()
parser.add_argument('--app_token', help='app token')
parser.add_argument('--table_id', help='table id')
parser.add_argument('--record_id', help='record id')
parser.add_argument('--fields', type=json.loads, help='fields to update')
parser.add_argument('--config_file', default='feishu-config.ini', help='config file path')
args = parser.parse_args()
# 调用封装的函数,使用命令行参数或默认值
response_body = UPDATE_RECORD(args.app_token, args.table_id, args.record_id, args.fields, args.config_file)
print(json.dumps(response_body, indent=4))
if __name__ == "__main__":
UPDATE_RECORD_CMD() # 调用封装的CMD函数