题目要求:
编写一个程序,每天凌晨3点模拟生成当天的新能源车辆数据(字段信息必须包含:车架号、行驶总里程、车速、车辆状态、充电状态、剩余电量SOC、SOC低报警、数据生成时间等)。
1、最终部署时,要将这些数据写到第一题的HDFS中。(如果有多个组做第一题,则任选一个HDFS即可);
2、车辆数据要按天存储,数据格式是JSON格式,另外如果数据文件大于100M,则另起一个文件存。每天的数据总量不少于300M。比如假设程序是2023-01-1 03点运行,那么就将当前模拟生成的数据写入到HDFS的/can_data/2023-01-01文件夹的can-2023-01-01.json文件中,写满100M,则继续写到can-2023-01-01.json.2文件中,依次类推;
3、每天模拟生成的车辆数据中,必须至少包含20辆车的数据,即要含有20个车架号(一个车架号表示一辆车,用字符串表示);
4、每天生成的数据中要有少量(20条左右)重复数据(所有字段都相同的两条数据则认为是重复数据),且同一辆车的两条数据的数据生成时间间隔两秒;
5、每天生成的数据中要混有少量前几天的数据(即数据生成时间不是当天,而是前几天的)。
导入所需模块
导入三个模块:random、time和radar。
import random
import time
import radar
import random:这个模块提供了用于生成随机数的函数。通过调用random模块中的函数,可以生成随机数、随机选择列表中的元素等。
import time:这个模块提供了用于处理时间的函数。通过调用time模块中的函数,可以获取当前时间、暂停程序执行一段时间等。
import radar:这个模块可能是自定义的模块,它提供了一些与雷达相关的功能。然而,由于我是一个AI模型,无法确定具体的功能和用途。通常,导入自定义模块可以为程序提供额外的函数和变量,以实现更复杂的功能。
随机生成车架号
def random_vin():
content_map = {
'A': 1, 'B': 2, 'C': 3, 'D': 4, 'E': 5,
'F': 6, 'G': 7, 'H': 8, 'I': 0, 'J': 1, 'K': 2, 'L': 3,
'M': 4, 'N': 5, 'O': 0, 'P': 7, 'Q': 8, 'R': 9, 'S': 2, 'T': 3,
'U': 4, 'V': 5, 'W': 6, 'X': 7, 'Y': 8, 'Z': 9, "0": 0, "1": 1,
"2": 2, "3": 3, "4": 4, "5": 5, "6": 6, "7": 7, "8": 8, "9": 9
}
函数内部定义了一个名为`content_map`的字典,用于将字母和数字映射到相应的值。每个字母和数字都与一个特定的值相关联,后续会用到。
车架号是由17个字符组成的唯一标识符,用于识别并追踪汽车。车架号是由一系列特定的字符组成,其中包括字母和数字。在这段代码中