常用数据类型转换函数

例一 u32类型数据传进 u8数组中

uint32_t DAL_Uint8ToUint32(uint8_t *p8Data)
{
	typedef union 
	{  //...
		uint8_t  au8Value[4];
		uint32_t u32Value;
	}tuValue;
	tuValue uValue;
	
	if(p8Data == NULL)	return 0;

	uValue.au8Value[0] = p8Data[3];
	uValue.au8Value[1] = p8Data[2];
	uValue.au8Value[2] = p8Data[1];
	uValue.au8Value[3] = p8Data[0];
	
	return uValue.u32Value;
}

u8数组传进 返回u32数据

uint32_t DAL_Uint8ToUint32(uint8_t *p8Data)
{
    typedef union 
    {  //...
        uint8_t  au8Value[4];
        uint32_t u32Value;
    }tuValue;
    tuValue uValue;
    
    if(p8Data == NULL)    return 0;

    uValue.au8Value[0] = p8Data[3];
    uValue.au8Value[1] = p8Data[2];
    uValue.au8Value[2] = p8Data[1];
    uValue.au8Value[3] = p8Data[0];
    
    return uValue.u32Value;
}

将串口接收的u8数组 转换成浮点型float

float DAL_Uint8Tof4Float(uint8_t *p8Data)
{
	typedef union 
	{  //...
		uint8_t  au8Value[4];
		float    fValue;
	}tuValue;
	tuValue uValue;
	
	if(p8Data == NULL)	return -1;

	uValue.au8Value[0] = p8Data[3];
	uValue.au8Value[1] = p8Data[2];
	uValue.au8Value[2] = p8Data[1];
	uValue.au8Value[3] = p8Data[0];
	
	return uValue.fValue;
}

浮点float转成u8数组

DAL_f4FloatToUint8(float fData,uint8_t *p8Data)
{
	typedef union 
	{  //...
		uint8_t  au8Value[4];
		float    fValue;
	}tuValue;
	tuValue uValue;
	
	if(p8Data == NULL)	return;

	uValue.fValue = fData;
	p8Data[0] = uValue.au8Value[3];
	p8Data[1] = uValue.au8Value[2];
	p8Data[2] = uValue.au8Value[1];
	p8Data[3] = uValue.au8Value[0];
}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spark提供了一系列的数据类型转换函数,用于在DataFrame或Dataset中进行数据类型的转换。以下是一些常用的Spark数据类型转换函数: 1. `cast()`函数:将列的数据类型转换为指定的数据类型。例如,将一个整数列转换为字符串列可以使用`df.select(col("age").cast(StringType()))`。 2. `to_date()`函数:将字符串列转换为日期类型。例如,将一个字符串列转换为日期类型可以使用`df.select(to_date(col("date_string"), "yyyy-MM-dd").alias("date"))`。 3. `to_timestamp()`函数:将字符串列转换为时间戳类型。例如,将一个字符串列转换为时间戳类型可以使用`df.select(to_timestamp(col("timestamp_string"), "yyyy-MM-dd HH:mm:ss").alias("timestamp"))`。 4. `unix_timestamp()`函数:将字符串列转换为Unix时间戳。例如,将一个字符串列转换为Unix时间戳可以使用`df.select(unix_timestamp(col("timestamp_string"), "yyyy-MM-dd HH:mm:ss").alias("unix_timestamp"))`。 5. `from_unixtime()`函数:将Unix时间戳转换为字符串格式。例如,将一个Unix时间戳列转换为字符串格式可以使用`df.select(from_unixtime(col("unix_timestamp"), "yyyy-MM-dd HH:mm:ss").alias("timestamp_string"))`。 6. `date_format()`函数:将日期或时间戳列按指定格式转换为字符串格式。例如,将一个日期列按指定格式转换为字符串格式可以使用`df.select(date_format(col("date"), "yyyy-MM-dd").alias("date_string"))`。 7. `coalesce()`函数:将多个列中的第一个非空值作为结果。例如,将多个列中的第一个非空值作为结果可以使用`df.select(coalesce(col("col1"), col("col2"), col("col3")).alias("result"))`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值