-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBullshit.py
116 lines (91 loc) · 4.07 KB
/
Bullshit.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
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
import json, random
'''
唬爛產生器原始作者
Bill Hsu (徐子修)
https://github.com/StillFantastic/bullshit
Python 版本作者
Darren Yang (楊德倫)
https://github.com/telunyang/python_bullshit_generator
'''
# 唬爛類別
class Bullshit:
# 建構子
def __init__(self):
# 讀取唬爛資料集
with open("./data.json", "r", encoding="utf8") as file:
self.dict_data = json.loads(file.read())
# 判斷目前句子是否結束
def isEnd(self, str):
if str != '' and str[-1] in "。?!?!":
return True
return False
# 產生唬爛句子
def generate(self, param_topic, param_min_length):
# 計算字數是否超過指定字數
min_length = 0
# 使用者輸入的可能是字串(例如 "100"),轉成數值
param_min_length = int(param_min_length)
'''
[隨機排序名人語錄]
範例
eg: "盧梭a,浪費時間是一樁大罪過。b"
eg: "莎士比亞a,本來無望的事,大膽嘗試,往往能成功。b"
'''
list_famous = self.dict_data['famous']
random.shuffle(list_famous)
'''
[隨機排序唬爛語錄]
範例
eg: "x的發生,到底需要如何實現,不x的發生,又會如何產生。"
eg: "x的出現,必將帶領人類走向更高的巔峰。"
'''
list_bullshit = self.dict_data['bullshit']
random.shuffle(list_bullshit)
# 生成文字資料
str_gen = ''
# 生成過程中,只要超過指定字數,則跳出迴圈
while min_length < param_min_length:
# 取得整數亂數,藉以決定建立新段落、產生名人語錄,還是唬爛語錄
int_rand = random.randint(0, 99)
'''
int_rand 範圍:
0 - 5 且 文字資料是句號、問號等作為結尾: 建立新段落
0 - 27: 使用名人語錄
28 - 99: 使用唬爛語錄
'''
# 根據整數亂數來決定生成的方向
if int_rand < 5 and self.isEnd(str_gen):
# 建立新段落
str_gen += "\n\n"
elif int_rand < 27:
# 倘若可用的名人語錄都被拿光了,則結束生成,跳出迴圈
if len(list_famous) == 0:
break
# 取得隨機排序後的名人語錄第 1 句
sentence_famous = list_famous.pop(0)
# 「曾說過、曾講過」之類的詞,用來取代名人語錄當中的 a 字元
str_before = self.dict_data['before'][ random.randint(0, len(self.dict_data['before']) - 1 ) ]
# 「這啟發了我、這不禁讓我深思」之類的詞,用來取代名人語錄當中的 b 字元
str_after = self.dict_data['after'][ random.randint(0, len(self.dict_data['after']) - 1) ]
# 取代名人語錄當中的 a 和 b 字元
sentence_famous = sentence_famous.replace("a", str_before)
sentence_famous = sentence_famous.replace("b", str_after)
# 合併生成字串
str_gen += sentence_famous
else:
# 倘若可用的唬爛語錄都被拿光了,則結束生成,跳出迴圈
if len(list_bullshit) == 0:
break
# 取得隨機排序後的唬爛語錄第 1 句
sentence_bullshit = list_bullshit.pop(0)
# 取代唬爛語錄當中的 x 字元
sentence_bullshit = sentence_bullshit.replace("x", param_topic)
# 合併生成字串
str_gen += sentence_bullshit
# 每次生成句子,都要重新計算生成字數
min_length = len(str_gen)
# 如果發現生成的句子當中,完全沒有自訂主題,則重新生成
if param_topic not in str_gen:
return self.generate(param_topic, param_min_length)
# 回傳結果
return str_gen