栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

爬取网页源码之scala篇

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

爬取网页源码之scala篇

为了获取网页代码,一般人是想到直接ctrl+s,就可以保存了。确实比较方便,但是如果遇到子网页比较多就不行了。

为了方便批量获取网页代码,一个会java或者scala的程序员就不一样了。
比如:

上代码:

import java.io.{File, PrintWriter}

import scalaj.http.Http



object GetWeb {
  def main(args: Array[String]): Unit = {
    //定义遍历变量
    var num =1
    //定义网址前缀
    var web_name1 = "http://www.pingfandeshijie.net/di-san-bu-"
    //定义网址后缀
    var web_name3=".html"
    //源码本地保存路径,three为文件名前缀
    var path1 = "C:\Users\liming\Desktop\pfsj\平凡世界第三部\"
    //文件名前缀
    var fix = "three"
    //文件后缀
    var path2 =".txt";
    //定义爬取次数
    var n = 54
    //循环获取网址源码并写入文件
    while (num<=n) {
      //将循环变量的值传递给num0并转化为字符串
      var num0=String.valueOf(num)
      //原网址序号为01-54
      if (num<10) num0 ="0"+num0
      //把网址的url拼接起来
      var web_name = web_name1+num0+web_name3
      //使用http获取网页的源码
      val txt =Http(web_name).timeout(100000000,100000000).asString.body
      println(txt)

      //拼接地址和文件名
      var file_name = path1+fix+num0+path2
      //把获取的源码写入文件中
      val printWriter_name = new PrintWriter(new File(file_name))
      printWriter_name.write(txt)
      //关闭PrintWriter流
      printWriter_name.close
      //循环加1
      num=num+1
      //跑一次休息两秒,防止被封ip
      println("为了防止ip被封,程序正在休息中")
      Thread.sleep(2000)
    }
 }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/690894.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号