字符串转换为整数

输入一个表示整数的字符串,把该字符串转换成整数并输出,例如输入字符串"345",则输出整数345。请完成函数StrToInt,实现字符串转换成整数的功能。


#include <stdio.h>
#include <assert.h>
#include <string.h>

static int strToInt(char *pcStr)
{
	int iIdx = 0;
	int iTmp = 0;
	int iLen = 0;

	assert(NULL != pcStr);
	iLen = strlen(pcStr);

	printf("Len is %d\n", iLen);

	/* 去掉字符串前面的非数字字符  */
	while ((pcStr[iIdx] < '0') || (pcStr[iIdx] >= '9'))
	{
		iIdx++ ;
	}

	while (iIdx < iLen)
	{
		iTmp *= 10;
		iTmp += (pcStr[iIdx] - '0');
		iIdx++ ;
	}

	return iTmp;
}

int main(int argc, char **argv)
{
	char *pcStr = "123456";
	int iResult = 0;

	iResult  = strToInt(pcStr);

	printf("%d\n", iResult);

	return 0;
}


### SQL中将字符串数据转换整数类型的方法 在SQL中,可以使用 `CONVERT` 或 `CAST` 函数将字符串类型的值转换整数类型。以下是详细的说明和示例代码。 #### 使用 `CONVERT` 函数 `CONVERT` 函数允许将一个数据类型的值显式转换为另一个数据类型。其语法如下: ```sql CONVERT(target_data_type, expression, style) ``` 其中,`target_data_type` 是目标数据类型(如 `INT`),`expression` 是要转换的值或列,`style` 是可选参数,用于指定日期或时间格式的样式[^5]。 以下是一个将字符串转换整数的示例: ```sql SELECT CONVERT(INT, '123') AS ConvertedInteger; ``` #### 使用 `CAST` 函数 `CAST` 函数是另一种将数据类型转换为另一种数据类型的方法。其语法较为简单: ```sql CAST(expression AS target_data_type) ``` 下面是一个使用 `CAST` 将字符串转换整数的示例: ```sql SELECT CAST('456' AS INT) AS ConvertedInteger; ``` 需要注意的是,如果字符串包含非数字字符,则会引发错误。例如,尝试将 `'abc'` 转换整数会导致转换失败并抛出异常。 #### 示例:处理无效字符串 为了确保安全性,在实际应用中可以结合 `ISNUMERIC` 函数来验证字符串是否可以安全地转换整数。以下是一个示例: ```sql SELECT CASE WHEN ISNUMERIC('123') = 1 THEN CAST('123' AS INT) ELSE NULL END AS SafeConversion; ``` #### 处理带符号的字符串 对于带有正负号的字符串,SQL Server 的 `CONVERT` 和 `CAST` 函数同样能够正确处理。例如: ```sql SELECT CONVERT(INT, '-789') AS NegativeInteger; ``` ```sql SELECT CAST('+101' AS INT) AS PositiveInteger; ``` 以上代码均能成功执行,并返回正确的整数值。 #### 注意事项 - 确保输入字符串仅包含有效的数字字符。否则,转换操作将失败并抛出错误。 - 如果需要处理更复杂的字符串整数转换逻辑,可能需要自定义函数或使用编程语言中的高级解析方法[^4]。 ### 示例代码总结 以下是使用 `CONVERT` 和 `CAST` 函数进行字符串整数转换的完整示例: ```sql -- 使用 CONVERT 函数 SELECT CONVERT(INT, '123') AS ConvertedInteger; -- 使用 CAST 函数 SELECT CAST('456' AS INT) AS ConvertedInteger; -- 安全转换示例 SELECT CASE WHEN ISNUMERIC('123') = 1 THEN CAST('123' AS INT) ELSE NULL END AS SafeConversion; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值