解决问题:java.lang.NumberFormatException:For input string: "null"

在这里插入图片描述

今天中午,在做数据清洗的时候,发现了这个数据格式错误,几次更改还是报错,最后发现,这里的“null”,其实就是“null”字符串,而不是String中的空值null。
因为这个数据是从mysql中传上来的,所以一直在看mysql中的数据,觉得是null,不是“null”,但是从mysql传到HDFS上时,它已经被转化成“null”了,所以,如果想要继续使用,就应该把判断条件改成判断字符串

int sum_mark;
            if (subjective_mark.equals("null")){
                 sum_mark = Integer.valueOf(objective_mark);
            }else {
                 sum_mark = Integer.valueOf(subjective_mark)+Integer.valueOf(objective_mark);
            }
            

OK!!

### 关于 `java.lang.NumberFormatException` 异常 #### 异常原因 `java.lang.NumberFormatException: null` 表明程序试图将一个 `null` 或者不符合数字格式的字符串转换为数值类型时发生错误。当调用诸如 `Integer.parseInt()` 这样的方法来解析字符串到整数或其他基本数据类型的包装类对象时,如果传入的是 `null` 或者不合法的字符序列,则会抛出此异常[^3]。 具体来说,在执行像下面这样的代码片段时可能会遇到这个问题: ```java String strNumber = null; int number = Integer.parseInt(strNumber); ``` 这段代码中的变量 `strNumber` 被设置为了 `null`,因此在尝试将其转换成整型的过程中触发了 `NumberFormatException` 的抛出[^4]。 #### 解决方案 为了避免此类异常的发生,可以采取以下措施之一: - **验证输入的有效性**:确保传递给解析函数的参数不是 `null` 并且遵循预期的数据模式。可以在实际调用之前先做简单的检查。 ```java public static int safeParseInt(String s) { if (s == null || !s.matches("-?\\d+")) throw new IllegalArgumentException("Invalid input"); return Integer.parseInt(s.trim()); } ``` - **捕获并处理异常**:通过使用 `try-catch` 结构围绕可能引发异常的操作,并提供适当的恢复逻辑或向用户反馈信息。 ```java try { String strNumber = "not a number"; int number = Integer.parseInt(strNumber); } catch (NumberFormatException e) { System.out.println("Error parsing integer from string."); // Handle the error appropriately here. } ``` - **利用正则表达式预校验**:对于更复杂的场景下,还可以考虑采用正则表达式的手段提前过滤掉那些明显不可能成功的转换请求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值