Skip to content

Latest commit

 

History

History
139 lines (106 loc) · 3.9 KB

README.md

File metadata and controls

139 lines (106 loc) · 3.9 KB

Earthquake Map

实时抓取地震网信息,3D可视化

流程

  • 中国地震台网爬取数据
  • 数据展示到3D地球上
  • 部署服务器,实时抓起数据,更新3D地球
  • 分析数据,对数据进行可视化

爬取数据

爬数据我们使用NodeJS,主要用到HTTP、cheerio、fs三个node模块。

#1. 请求数据

这里会用到HTTP模块,去请求中国地震台网官网,之后返回一段HTML代码

// 目标url
const pageUrl = "http://news.ceic.ac.cn/index.html"

// 请求url,返回html
http.get(pageUrl, function(res) {
    let html = '';
    res.on('data', function(data) {
        html += data;
    });
    res.on('end', function() {
        //数据获取完,执行回调函数,处理html
        dealHTML(html);
    });
});

#2. 处理返回的html,得到想要的数据

这里需要用到node的cheerio模块,处理返回的html,操作和JQuery一样

// 处理HTML
function dealHTML(html) {
    //使用load方法,参数是刚才获取的html源代码数据
    let $ = cheerio.load(html);
    let dataArr = [];
    
    //写法和jQuery一模一样
    $('#news').find('tr').each(function(index, element) {
        if (element.children.length == 13 && element.children instanceof Array) {
            let temp = []
            for (let i = 0; i < element.children.length; ++i) {
                let cur = element.children[i]
                if (cur.name == 'td') {

                    if (!cur.children[0].data){
                        temp.push("'" + cur.children[0].children[0].data + "'")
                    } else {
                        temp.push("'" + cur.children[0].data + "'")
                    }
                    
                }
            }
            dataArr.push(temp)
        }
    });
    // 将处理后的数据写入文件
    writeFile(__dirname + '/output.js', dataArr)
}

#3. 将处理后的数据写入文件

这里需要用到node的fs模块,调用系统API操作文件

// 写文件
function writeFile(file, data){  

    let str = '',
        headStr = 'let data = [ //震级(M) 发震时刻(UTC+8) 纬度(°) 经度(°) 深度(千米) 地区 \n',
        footStr = '] \n'

    for (let i = 0; i < data.length; ++i) {
        str += '[' + data[i] + ']' + ',' + '\n'
    }  

    str = headStr + str + footStr

    // 将数据写到output.js中
    fs.writeFile(file, str,function(err, data){
        if(err) {
            console.log(file+'写文件操作失败:',err);
        } else {
            console.log("写文件操作成功"+file);
        }    
    });
}

想要的数据已经得到了:

// output.js
let data = [ //震级(M) 发震时刻(UTC+8) 纬度(°) 经度(°) 深度(千米) 地区 
['3.7','2017-11-23 10:14:12','29.81','95.15','6','西藏林芝市巴宜区'],
['5.2','2017-11-22 22:20:10','23.71','120.60','16','台湾云林县'],
['3.2','2017-11-22 15:50:08','38.54','73.92','110','塔吉克斯坦'],
['3.6','2017-11-22 04:10:58','30.05','85.58','8','西藏阿里地区措勤县'],
['3.0','2017-11-21 21:15:20','38.33','75.81','131','新疆克孜勒苏州阿克陶县'],
['2.1','2017-11-21 13:52:12','39.78','118.46','8','河北唐山市古冶区'],
['4.7','2017-11-21 02:26:25','35.36','86.57','7','西藏那曲地区尼玛县'],
['2.4','2017-11-20 08:58:15','30.68','108.38','5','重庆万州区(有感)'],
['6.9','2017-11-20 06:43:30','-21.28','168.71','20','新喀里多尼亚'],
['3.1','2017-11-20 05:47:08','29.39','104.05','15','四川乐山市犍为县'],
...
...
...
] 

接下来就可以画地球了:)

画地球

学习three.js

边学边翻译了一些英文资料

draw earth ing

资料

https://www.cnblogs.com/Aralic/p/4591036.html https://www.cnblogs.com/shawn-xie/archive/2012/08/16/2642553.html