自定义生成B站查成分脚本的脚本

基于三相之力

下载了 三相之力·蒸蒸日上脚本(三相之力脚本的三国杀拓展),然后修改成自定义生成脚本的脚本

说明

仅支持单标签

不支持混合标签,不支持多级标签

不能完美检测出成分,也可能会误伤无辜

效果预览

1111

222

食用方法

1.通过修改最上方mydict变量中的内容配置自定义规则

举例:在下方代码中,文明是可以显示在网页上的标签,keywords后面的内容是检测关键字,若检测到某用户与这些关键字有关时,就会给对应用户打上标签,color代表标签的颜色,可以搜索"rgb颜色表"查阅详细

1
2
3
4
5
6
7
8
'文明': {
'keywords': [
'肝文明', '玩文明', '打文明', '文明4', '文明5', '文明6', '文明VI', '统治胜利',
'科技胜利', '文化胜利', '外交胜利', '分数胜利', '宗教胜利', '老秦', '无战飞',
'黄金国'
],
'color': '#c929f5',
},

2.直接运行python脚本,运行完后会在脚本同目录生成一个叫BStationElementSerach.txt的文件

3.打开BStationElementSerach.txt,全选,复制,在油猴插件中新建脚本,粘贴,完工!

代码

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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
from typing import Any, Union

REFRESH_SEP = 4000

mydict: dict[str, dict[str, Union[list[str], str]]] = {
'文明': {
'keywords': [
'肝文明', '玩文明', '打文明', '文明4', '文明5', '文明6', '文明VI', '统治胜利',
'科技胜利', '文化胜利', '外交胜利', '分数胜利', '宗教胜利', '老秦', '无战飞',
'黄金国'
],
'color': '#c929f5',
},
'洞口骑士': {
'keywords': [
'空洞骑士', '洞口骑士', '丝之鸽', '丝之歌', '苦痛之路', '辐辉', '佐特', '奎若', '蓝湖',
'r45', '小骑士', '辐光', '龙牙哥', '龙牙姐', '三螳螂', '力量快劈', '稳体', '四锁',
'遗忘十字路', '苍绿之径', '真菌荒地', '雾之峡谷', '古老盆地', '皇家水道', '王国边缘',
'乌恩', '愚人竞技场', 'jjc3', '亡怒', '钢魂', '白色宫殿', '酸冲', '劈魂', '骨钉', '马爹',
'毛里克', '下砸', '劈波', '扭波', '0白'
],
'color': '#2532e9',
},
'蔚蓝': {
'keywords' : [
'蔚蓝', '玛德琳', 'celeste', 'Celeste', '兔子跳', '蹭墙跳', '大跳', '凌波',
'无体力上墙', '春三', '春四', '春五', '春3', '春4', '春5', '金草莓'
],
'color': '#ff2e42',
},
'求批': {
'keywords' : [
'求生之路', '打求', 'tank', 'witch', '药抗', '药役', '挂边躲牛','evo', '1tc', 'mayuyu',
'秒妹', 'Anne', 'diandian', 'zonemod', '消耗克', '吸铁', 'hunter', '一位喷', 'charger',
'jockey', 'spitter','smoker', 'boomer', 'RBT', 'VGT', 'nv', 'pubstar', 'amagami',
'特感'
],
'color': '#b93837',
},
# '小黑子':{
# 'keywords' : [
# '鸡你太美', 'ikun', '蔡徐坤', '只因', '坤坤', '两年半', '个人练习生', '你干嘛', '唱跳rap',
# '小黑子'
# ],
# 'color': '#d7af0f',
# },

}


MAIN_STRING = '''
// ==UserScript==
// @name 程序自动生成的B站成分查看脚本
// @namespace ScriptForAutoGenerateBStationElementSearchScript
// @version 0.1
// @description 自动生成的B站成分查看脚本, 暂不支持混合标签
// @author xulaupuz&nightswan&高贵乡公&脚本使用者
// @match https://www.bilibili.com/video/*
// @match https://www.bilibili.com/bangumi/play/*
// @match https://t.bilibili.com/*
// @match https://space.bilibili.com/*
// @match https://space.bilibili.com/*
// @match https://www.bilibili.com/read/*
// @icon https://static.hdslb.com/images/favicon.ico
// @connect bilibili.com
// @grant GM_xmlhttpRequest
// @license MIT
// @run-at document-end
// ==/UserScript==


(function () {{
'use strict';
const unknown = new Set()

//成分,可自定义
const nor = new Set()
{CODE_define_set}


//关键词,可自定义
{CODE_define_keyword}

//贴上标签,可自定义
const tag_nor = " [普通]"
{CODE_define_tag}


const blog = 'https://api.bilibili.com/x/polymer/web-dynamic/v1/feed/space?&host_mid='
const is_new = document.getElementsByClassName('item goback').length != 0 // 检测是不是新版

//标签颜色,可自定义,默认为B站会员色
const tag_nor_Inner = "<b style='color: #11DD77'>" + tag_nor + "</b>"
{CODE_define_Inner}


const get_pid = (c) => {{
if (is_new) {{
return c.dataset['userId']
}} else {{
return c.children[0]['href'].replace(/[^\d]/g, "")
}}
}}

const get_comment_list = () => {{
if (is_new) {{
let lst = new Set()
for (let c of document.getElementsByClassName('user-name')) {{
lst.add(c)
}}
for (let c of document.getElementsByClassName('sub-user-name')) {{
lst.add(c)
}}
return lst
}} else {{
return document.getElementsByClassName('user')
}}
}}


console.log(is_new)
console.log("正常加载")


let jiance = setInterval(() => {{
let commentlist = get_comment_list()
if (commentlist.length != 0) {{
// clearInterval(jiance)
commentlist.forEach(c => {{
let pid = get_pid(c)

{CODE_add_Inner}

if (nor.has(pid)) {{
if (c.textContent.includes(tag_nor) === false) {{
c.innerHTML += tag_nor_Inner
}}
return
}}

unknown.add(pid)
//console.log(pid)
let blogurl = blog + pid
// let xhr = new XMLHttpRequest()
GM_xmlhttpRequest({{
method: "get",
url: blogurl,
data: '',
headers: {{
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36'
}},
onload: function (res) {{
if (res.status === 200) {{
//console.log('成功')
let st = JSON.stringify(JSON.parse(res.response).data)

unknown.delete(pid)

let tag_flag = false

{CODE_add_tag}

//添加纯良标签
if (!tag_flag) {{
c.innerHTML += tag_nor_Inner
nor.add(pid)
}}
}} else {{
console.log('失败')
console.log(res)
}}
}},
}});
}});
}}
}}, {refresh_sep})
}})();

'''

def define_one_set(tag_name: str) -> str:
_ = f'const set_{tag_name} = new Set()\n'
return _

def define_one_tag(tag_name: str) -> str:
_ = f'const tag_{tag_name} = " [{tag_name}]"\n'
return _

def define_one_keyword(keyword_name: str) -> str:
_ = f'const keyword_{keyword_name} = "{keyword_name}"\n'
return _

def define_one_Inner(tag_name: str, color = None) -> str:
style = '' if not color else f'style=\'color: {color}\''
_ = f'const tag_Inner_{tag_name} = "<b {style}>" + tag_{tag_name} + "</b>"\n'
return _


def add_one_tag(tag_name: str):
lst: list[str] = mydict[tag_name]['keywords']
_keywords_judge = f'st.includes(keyword_{lst[0]})'
for each_keyword in lst[1 : ]:
_keywords_judge += f' || st.includes(keyword_{each_keyword})'

_ = '''
if ({CODE_keywords_judge}) {{
c.innerHTML += {CODE_Inner}
{CODE_set}.add(pid)
tag_flag = true
}}
'''.format(
CODE_keywords_judge = _keywords_judge,
CODE_Inner = f'tag_Inner_{tag_name}',
CODE_set = f'set_{tag_name}',
)
return _

def add_one_Inner(tag_name: str) -> str:
_='''
if ({CODE_set}.has(pid)) {{
if (c.textContent.includes({CODE_tag}) === false) {{
c.innerHTML += {CODE_Inner}
}}
return
}}
'''.format(
CODE_set = f'set_{tag_name}',
CODE_tag = f'tag_{tag_name}',
CODE_Inner = f'tag_Inner_{tag_name}',
)
return _

def install_tags():
CODE_define_set = ''
CODE_define_keyword = ''
CODE_define_tag = ''
CODE_define_Inner = ''
CODE_add_tag = ''
CODE_add_Inner = ''

unique_keyword = set()

for key, value in mydict.items():
keywords, color = value['keywords'], value['color']

CODE_define_set += define_one_set(key)
CODE_define_tag += define_one_tag(key)
CODE_define_Inner += define_one_Inner(key, color)
for each_keyword in keywords:
if each_keyword not in unique_keyword:
CODE_define_keyword += define_one_keyword(each_keyword)
unique_keyword.add(each_keyword)

CODE_add_tag += add_one_tag(key)
CODE_add_Inner += add_one_Inner(key)

_ = MAIN_STRING.format(
CODE_define_set = CODE_define_set,
CODE_define_tag = CODE_define_tag,
CODE_define_Inner = CODE_define_Inner,
CODE_define_keyword = CODE_define_keyword,
CODE_add_tag = CODE_add_tag,
CODE_add_Inner = CODE_add_Inner,
refresh_sep = REFRESH_SEP
)
return _

def run():
with open('BStationElementSerach.txt', 'w', encoding='utf-8') as f:
f.write(install_tags())

if __name__ == '__main__':
run()