拉取百度汉语的成语接龙脚本

成语不存在或期望的接龙长度超出可查询范围时会报错,不过凑合能找到部分接龙的成语,记录之。

#encoding:GBK

require 'net/http'
require 'nokogiri'

def get_alist(url)
	puts url
	$stdout.flush
	res = Net::HTTP.get_response(URI.parse(url))
	doc = Nokogiri::HTML res.body
	return doc.xpath("//*[@id='jielong-wrapper']")[0].css('div')[0].css('a')
end

def build_long(ci,long,maxlen)
	url = "http://hanyu.baidu.com/s?wd=#{URI.escape(ci.encode('utf-8'))}&cf=jielong&ptype=idiom"
	alist = get_alist(url)
	i = 1
	alist.each do |a|
		if long.has_key?(a.text) then
			return build_long(a.text,long,maxlen)
		else
			long[a.text] = 0
			return long if long.size > maxlen
			return build_long(a.text,long,maxlen) if alist.size <= i
		end
		i = i + 1
	end
end

start_chengyu = '尔虞我诈'
max_length = 20
long = Hash.new
long = build_long(start_chengyu,long,max_length - 1)
result_file = File.open('成语接龙结果文件.txt','w')
long.each do |k,v|
	result_file.puts k
end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值