字符串转换为整数

/*
 * =====================================================================================
 *
 *       Filename:  StrtoI.cpp
 *
 *    Description:  
 *
 *        Version:  1.0
 *        Created:  2014年02月28日 14时18分33秒
 *       Revision:  none
 *       Compiler:  gcc
 *
 *         Author:  Dr. Fritz Mehner (mn), mehner@fh-swf.de
 *        Company:  FH Südwestfalen, Iserlohn
 *
 * =====================================================================================
 */
#include<iostream>
#include<cstring>
using namespace std;

class StrtoInt
{
	public:
		StrtoInt(const char *st):mark(false),positive(-1),minus(-1){
			s = new char[strlen(st)+1];
			strncpy(s,st,strlen(st));
		}
		int getnum();
		
		bool mark;//标记是否转换有效。可以判断数字0是否是返回的正确结果或者错误信息
	private:
		//char *s;
		int strtoi();
		int positive;//标记正号
		int minus;//标记负号
		char *s;
};
int StrtoInt::strtoi()
{
	int length = strlen(s);
	int sum = 0;
	if(NULL == s)
		return 0;
	if(('+'==*s||'-'==*s)&&1==strlen(s))
		return 0;
	if('+' == *s&&strlen(s)>1)
		positive = 1;
	if('-' == *s&&strlen(s)>1)
		minus = 2;
	if('+' == *s || '-'== *s)
	for(int i = 1; i < length;i++)
	{
		if(s[i] >= '0' && s[i] <= '9')
		{
			sum = sum*10+(s[i] - '0');//累加
		}
		else 
			return 0;
		mark = true;//把标记位设置为真。
	}
	else
	{
		for(int i = 0; i < length; i++)
		{
			if(s[i] >= '0' && s[i] <= '9')
			{
				sum = sum*10+(s[i] - '0');
			}else return 0;

		}
		mark = true;
	}
    return sum;
}
int StrtoInt::getnum()
{
	int num = strtoi();
	if(num == 0 && mark == true)
		return 0;
	if(positive == 1)
		return num;
	if(minus == 2)
		return (0-num);
	return num;
}
int main()
{
	StrtoInt ch("123");
	StrtoInt ch1("-123");
	StrtoInt ch2("f23");
	cout << ch.getnum() << endl;
	cout << ch1.getnum()<<endl;
	cout << ch2.getnum() << endl;
	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、付费专栏及课程。

余额充值