字符串转换为整数

  class Program
    {
        static void Main(string[] args)
        {

  int result = StrConverter.Convert("123.45");
            Console.WriteLine(result);

            try
            {
                double t1 = int.MaxValue;
                t1 = t1 + 1;
                int max = StrConverter.Convert(t1.ToString());
            }
            catch (Exception ee)
            {
                Console.WriteLine(ee.Message);
            }

            Console.Read();

}}

 

 /// <summary>
    /// 转换类
    /// </summary>
   public  class StrConverter
    {

        /// <summary>
        /// 将形如 123.45 这样的字符串,转化为 123 这样的整型数
        /// </summary>
        /// <param name="src"></param>
        /// <returns></returns>
      public  static Int32 Convert(string src)
        {

            if (string.IsNullOrEmpty(src))
            {
                throw new Exception("不可为空");
            }

            bool positive = true;
            Int32 result = 0;
            double tempResult = 0;
            int start = 0;

            while (start <= src.Length - 1 && src[start] == ' ')
            {

                if (start == Int16.MaxValue)
                {

                    throw new Exception("空格太多" + start);


                }
                start++;

            }


            if (start <= src.Length - 1 && src[start] == '-')
            {
                positive = false;
                start++;
            }


            for (int i = start; i < src.Length; i++)
            {
                int charInt = FromChar2Int(src[i]);
                if (IsNumber(src[i]))
                {

                    tempResult = tempResult * 10 + charInt;
                    result = result * 10 + charInt;

                }
                else if (src[i] == '.')
                {
                    break;
                }
                else
                {
                    throw new Exception("非法字符.位置" + i + " " + src[i]);
                }

                if (positive)
                {
                    if (tempResult > ((double)Int32.MaxValue - 1))
                    {
                        throw new Exception("超出整形范围,太大了");
                    }
                }
                else
                {
                    if (tempResult > ((double)Int32.MaxValue + 1))
                    {
                        throw new Exception("超出整形范围,太小了");
                    }
                }


            }

            if (positive)
            {
                return result;
            }
            else
            {
                return -1 * result;
            }


        }

        static bool IsNumber(char c)
        {
            int code = (int)c - 48;
            if (code > 9 || code < 0)
            {
                return false;
            }
            return true;
        }

        static Int32 FromChar2Int(char c)
        {
            int code = (int)c - (int)'0';
            return code;
        }

   
    }

 

  

### 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、付费专栏及课程。

余额充值