狗屁不通生成器

狗屁不通生成器

  在看到网上的狗屁不通生成器之后,我觉得挺有意思,于是也想用python写一个。

  • 思路:

    • 输入文章主题和写几句话
    • 创建文件并打开
    • 读取素材并随机挑选一句写入文件
    • 关文件
  • 用到的模块:

    • random:随机挑选一句话
    • json:读取素材文件
import random as r
import json as j

上代码

def random_summon():
	"""生成函数"""
	filename='texts.json'
	
	#指定主题
	topic=input('请输入主题:')
	
	#指定篇幅
	n=input('请指定几句话(默认为100):')
	try:
		n=int(t)
	except:
		n=100
	
	#文档的标题
	t=r.randint(0,1)
	if t==1:
		f_name='%s%s%s'%('谈',topic,'.txt')
	else:
		f_name='%s%s%s'%('论',topic,'.txt')
	
	#加载文本的句子素材
	try:
		with open(filename) as f:
			sentences=j.load(f)
			l1=sentences[0]
			l2=sentences[1]
	except:
		with open(filename,'w') as f:
			txt=[['加油,奥利给!'],['马克思说过:“生活就像海洋,只'\
			'有意志坚强的人,才能到达彼岸。”']]
			j.dump(txt,f)
		with open(filename) as f:
			sentences=j.load(f)
			l1=sentences[0]
			l2=sentences[1]
		
	#新建文档
	article=open(f_name,'w')
	#写作的主体循环
	i=0#控制循环次数
	ii=0#控制分段
	n_p=r.randint(8,18)#每段的句子数量
	
	while i<=n:
		ii+=1
		#从哪个素材库里面选句子
		#l1是其他的话,l2是名人名言
		zerone=r.randint(0,1)
		if zerone == 0:
			s_n=r.randint(0,len(l1)-1)
			sentence=l1[s_n].replace('a',topic)
			#这里,所有的a都被topic替换掉
			#因为录入素材的时候用的是a作为替换内容
		else:
			s_n=r.randint(0,len(l2)-1)
			sentence=l2[s_n].replace('a',topic)
		
		#分段及换行
		if ii == 1:
			sentence='%s%s'%('\t',sentence)
		elif ii == n_p:
			sentence='%s%s'%(sentence,'\n')
			n_p=r.randint(8,18)#每段的句子数量
			ii=0
		
		#写进文章
		article.write(sentence)
		
		i+=1
	
	article.close()
	print('完成\n')

训练工具

  为了丰富我们生成的文章的内容,尽量减少重复,我们要对素材库——texts.json,进行扩充。因为存储的是json格式所以需要转码,直接复制粘贴就行不通了,所以我们需要一个训练工具。

  • 思路:

    • 尝试读取素材,如果素材库不存在就创建一个
    • 用户循环输入要添加的素材并将其添加到刚刚读取的素材列表中
    • 重新写入素材
  • 用到的模块

    • json:读取素材文件
import json as j

上代码

def train():
	"""训练函数"""
	filename='texts.json'
	
	while True:
		try:
			f=open(filename,'r')
		except:
		#素材库不在,就创建一个
			f=open(filename,'w')
			txt=[['加油,奥利给!'],['马克思说过:“生活就像海洋,只'\
			'有意志坚强的人,才能到达彼岸。”']]
			j.dump(txt,f)
			f.close()
		else:
			sentence=input('说些什么吧,我会记住的哦~(输入q退出训练)\n')
			sentences=j.load(f)
			if sentence == 'q':
				break
			else:
				yn=input('这是名人名言吗? Y/N\n')
				if yn == 'y' or 'Y':
					sentences[1].append(sentence)
				else:
					sentences[0].append(sentence)

	f.close()
	with open(filename,'w') as texts:
		j.dump(sentences,texts)

帮助函数(可有可无)

废话不多(也没有可bb的了),上代码

def example():
	"""帮助函数"""
	print('举例:输入1\n1\n说些什么吧,我会记住的哦~(输入q退出训练)')
	print('坚持就是胜利。\n这是名人名言吗? Y/N\nN')
	print('说些什么吧,我会记住的哦~(输入q退出训练)\nq\n')
	print('举例:输入2\n2\n请输入主题:学习')
	print('请指定几句话(默认为100):120\n完成\n')

运行函数

  为了将以上所编写的函数组织起来,再编写一个简易的函数

废话不多,上代码

def run():
	"""运行函数"""
	c=''
	while c!='q'or'Q':
		c=input('请选择模式:\t0.帮助\t1.训练\t2.写作\t3.退出\n')
		try:
			c=int(c)
		except:
			print('请重新输入。\n')
		else:
			if c == 1:
				train()
				continue
			elif c == 2:
				random_summon()
				continue
			elif c == 0:
				example()
				continue
			elif c == 3:
				print('拜拜~')
				break
			else:
				print('请重新输入。\n')
				continue

整合代码

#article.py

import random as r
import json as j

#为了方便调用,我们把filename(素材库的变量名)定义在外面
global filename#这里不声明全局变量也可以
filename='texts.json'

def random_summon():
	"""生成函数"""
	
	#指定主题
	topic=input('请输入主题:')
	
	#指定篇幅
	n=input('请指定几句话(默认为100):')
	try:
		n=int(t)
	except:
		n=100
	
	#文档的标题
	t=r.randint(0,1)
	if t==1:
		f_name='%s%s%s'%('谈',topic,'.txt')
	else:
		f_name='%s%s%s'%('论',topic,'.txt')
	
	#加载文本的句子素材
	try:
		with open(filename) as f:
			sentences=j.load(f)
			l1=sentences[0]
			l2=sentences[1]
	except:
		with open(filename,'w') as f:
			txt=[['加油,奥利给!'],['马克思说过:“生活就像海洋,只'\
			'有意志坚强的人,才能到达彼岸。”']]
			j.dump(txt,f)
		with open(filename) as f:
			sentences=j.load(f)
			l1=sentences[0]
			l2=sentences[1]
		
	#新建文档
	article=open(f_name,'w')
	#写作的主体循环
	i=0#控制循环次数
	ii=0#控制分段
	n_p=r.randint(8,18)#每段的句子数量
	
	while i<=n:
		ii+=1
		#从哪个素材库里面选句子
		#l1是其他的话,l2是名人名言
		zerone=r.randint(0,1)
		if zerone == 0:
			s_n=r.randint(0,len(l1)-1)
			sentence=l1[s_n].replace('a',topic)
			#这里,所有的a都被topic替换掉
			#因为录入素材的时候用的是a作为替换内容
		else:
			s_n=r.randint(0,len(l2)-1)
			sentence=l2[s_n].replace('a',topic)
		
		#分段及换行
		if ii == 1:
			sentence='%s%s'%('\t',sentence)
		elif ii == n_p:
			sentence='%s%s'%(sentence,'\n')
			n_p=r.randint(8,18)#每段的句子数量
			ii=0
		
		#写进文章
		article.write(sentence)
		
		i+=1
	
	article.close()
	print('完成\n')


def train():
	"""训练函数"""
	
	while True:
		try:
			f=open(filename,'r')
		except:
		#素材库不在,就创建一个
			f=open(filename,'w')
			txt=[['加油,奥利给!'],['马克思说过:“生活就像海洋,只'\
			'有意志坚强的人,才能到达彼岸。”']]
			j.dump(txt,f)
			f.close()
		else:
			sentence=input('说些什么吧,我会记住的哦~(输入q退出训练)\n')
			sentences=j.load(f)
			if sentence == 'q':
				break
			else:
				yn=input('这是名人名言吗? Y/N\n')
				if yn == 'y' or 'Y':
					sentences[1].append(sentence)
				else:
					sentences[0].append(sentence)

	f.close()
	with open(filename,'w') as texts:
		j.dump(sentences,texts)


def example():
	"""帮助函数"""
	print('举例:输入1\n1\n说些什么吧,我会记住的哦~(输入q退出训练)')
	print('坚持就是胜利。\n这是名人名言吗? Y/N\nN')
	print('说些什么吧,我会记住的哦~(输入q退出训练)\nq\n')
	print('举例:输入2\n2\n请输入主题:学习')
	print('请指定几句话(默认为100):120\n完成\n')


def run():
	"""运行函数"""
	c=''
	while c!='q'or'Q':
		c=input('请选择模式:\t0.帮助\t1.训练\t2.写作\t3.退出\n')
		try:
			c=int(c)
		except:
			print('请重新输入。\n')
		else:
			if c == 1:
				train()
				continue
			elif c == 2:
				random_summon()
				continue
			elif c == 0:
				example()
				continue
			elif c == 3:
				print('拜拜~')
				break
			else:
				print('请重新输入。\n')
				continue


run()

END
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值