学习电商数仓搭建时,遇到创建DIM层的时间维度表。这里时间维度表数据是十分固定的(一年一更新),要将这些数据提出出来生成文件以便导入DIM层的时间维度表中。
我们可以调用网络上免费的节假日API来实现对数据的整合和统计。
具体代码如下:
这里建议使用第二种getDate2的API,注意使用第二种时需要你自己去申请app_id和app_secret去替换
package com.time;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
/**
*
* 制作时间维度表数据(日期,周,周几,每月第几天,第几月,第几季度,年,是否为鸽子肉,节假日)
* @author csw
* @time 2022/4/20 9:55
*/
public class TimeProduce {
static BufferedReader in = null;
static BufferedWriter writer = null;
public static void main(String[] args) throws FileNotFoundException, UnsupportedEncodingException {
writer = new BufferedWriter(new OutputStreamWriter(new FileOutputStream("D:\\study\\data\\date.txt"), "UTF-8"));
// getDate1();
getDate2();
close();
}
/**
* @Author: csn
* @Description: 建立API调用连接
* @DateTime: 2022/4/20 14:14
* @Params:
* @Return 字符串(日期数据)
*/
public static StringBuffer getConnect(String url) {
URL url1;
StringBuffer sb = new StringBuffer();
try {
url1 = new URL(url);
HttpURLConnection connection = (HttpURLConnection) url1.openConnection();
connection.setRequestMethod("GET");
connection.setRequestProperty("User-Agent", "Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/61.0.3163.100 Safari/537.36)"); //防止报403错误。
connection.connect();

该博客介绍了如何在学习电商数仓搭建过程中创建时间维度表。作者通过调用网络上的免费节假日API,实现了数据的整合和统计,并提供了具体的Java代码示例。代码包括了从API获取数据,解析JSON,处理日期和节假日信息,并将结果写入文件的过程。此方法用于生成一年一更新的时间维度表数据。
最低0.47元/天 解锁文章
4449

被折叠的 条评论
为什么被折叠?



