免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4267 | 回复: 9
打印 上一主题 下一主题

关于Use of uninitialized value in substitution/join [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-06-01 16:27 |只看该作者 |倒序浏览
我用split将CSV文件导入数组存储, 然后对数组元素进行需要的处理.这之中会时不时将某些数组元素就变成undef.
这样如果再对这些数组元素做处理的时候就会产生诸如这些个warning: Use of uninitialized value in substitution/join,虽然不影响程序运行的正确性.
现在的解决办法是join之前, 遍历一边数组, 如发现元素是undef的就用空窜替代. 但感觉这样的方法很臃肿.
不知有没有更加好的方法.
谢谢!

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
2 [报告]
发表于 2012-06-01 16:31 |只看该作者
你的 CSV 列数并不都相同吧,split 本身是不会产生 undef 值的。

论坛徽章:
0
3 [报告]
发表于 2012-06-01 16:37 |只看该作者
本帖最后由 sellie 于 2012-06-01 16:40 编辑

CSV列数是相同的,但本身有些域就是空的. undef不是在split中产生的, 是我后续的一些操作产生的, 比如去首尾空格, 去nonascii字符.示例代码如下

while ( my $row = <$RFH> ) {
    chomp $row;
    $row =~ s/[[:^ascii:]]+//gxms;
    my @fields = (split /,/xms, $row)[0..10];
    for (@fields) {  s/^\s+|\s+$//gxms }
}

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
4 [报告]
发表于 2012-06-01 17:12 |只看该作者

    my @fields = (split /,/xms, $row)[0..10]; 这里如果没有11个元素就会用 undef 补充

论坛徽章:
1
狮子座
日期:2013-12-16 16:09:24
5 [报告]
发表于 2012-06-01 17:32 |只看该作者
  1. #!perl
  2. use strict;
  3. use warnings;
  4. use Data::Dumper;
  5. use 5.010;
  6. my @x = map { $_ // '' } (('a') x 5,(undef) x 5);
  7. print Dumper @x;
复制代码

论坛徽章:
0
6 [报告]
发表于 2012-06-01 17:37 |只看该作者
zhlong8 发表于 2012-06-01 17:12
my @fields = (split /,/xms, $row)[0..10]; 这里如果没有11个元素就会用 undef 补充



CSV文件都是11列以上的, 因为我只关心前11列的内容,所以截取了.

论坛徽章:
0
7 [报告]
发表于 2012-06-01 17:39 |只看该作者
ttcn_cu 发表于 2012-06-01 17:32


这个就是我现在做的,把undef用空窜替换掉.
但我觉得这样很不爽.

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
8 [报告]
发表于 2012-06-01 18:00 |只看该作者
sellie 发表于 2012-06-01 17:37
CSV文件都是11列以上的, 因为我只关心前11列的内容,所以截取了.


如果真是这样那这段代码哪里会产生 undef 值,我还真想不出来,你在前面加个测试检测下 split 返回的数目是否达到11

论坛徽章:
1
狮子座
日期:2013-12-16 16:09:24
9 [报告]
发表于 2012-06-01 18:51 |只看该作者
本帖最后由 ttcn_cu 于 2012-06-01 18:53 编辑

可以有很多很诡异的写法啊 ,当然用的时候一定要加上注释
  1. #!perl
  2. use strict;
  3. use warnings;
  4. use Data::Dumper;
  5. my $g='a,b,c,d,e,f';
  6. my @x = (split(/,/,$g), (q{}) x 10 ) [0..10];
  7. print Dumper @x;
复制代码

论坛徽章:
0
10 [报告]
发表于 2012-06-05 17:39 |只看该作者
zhlong8 发表于 2012-06-01 18:00
如果真是这样那这段代码哪里会产生 undef 值,我还真想不出来,你在前面加个测试检测下 split 返回的数 ...


今天仔细的加了测试节点揪问题. 还是split引起的.
我有些条目只有前7个域有值,如下
0,1,2,3,4,5,6,,,,,,,,,,,,,,,,,,,,
这样split后付给数组的话从第8个元素就是undef了.
解决的方法是在每个条目最后的域附上一个值,比如NA
0,1,2,3,4,5,6,,,,,,,,,,,,,,,,,,,,NA,
这样split后付给数组那些空的域就成为''而不是undef了.

对split的行为还是不够深入了解.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP