免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: HF.SKY000
打印 上一主题 下一主题

PERL中怎么删除一空行 [复制链接]

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
11 [报告]
发表于 2008-11-30 18:02 |只看该作者
while (my $line=$sth->fetchrow_array) {
push @ne_id_sz,"$line\n";
my $size=@ne_id_sz;
print $size,"\n";
$sth->finish;
}

这是个循环。取出多少行记录就会打印多少次数组的个数。

$sth->execute;后取到一个记录集,类似这样:
记录    字段1    字段2   ....
1          abc       xxxx
2          def        xxxx
...

while (my $line=$sth->fetchrow_array) 应该写成:while (@row=$sth->fetchrow_array)
每次取一个记录(@row的每个元素是select指定的字段)。@row 分别等于 (abc, xxx),  (def, xxx) ....

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
12 [报告]
发表于 2008-11-30 18:12 |只看该作者
原帖由 ynchnluiti 于 2008-11-30 18:02 发表

这是个循环。取出多少行记录就会打印多少次数组的个数。

$sth->execute;后取到一个记录集,类似这样:
记录    字段1    字段2   ....
1          abc       xxxx
2          def        xxxx
...

...

不是line和row的区别。
@line, @row都可以,或者其它名字。

论坛徽章:
0
13 [报告]
发表于 2008-11-30 19:07 |只看该作者
原帖由 HF.SKY000 于 2008-11-30 17:29 发表
说得对,在FOR循环PRINT多带了一个"\N".
再请教个问题:

for (my $i=0;$iprepare($s);
$sth->execute;
while (my $line=$sth->fetchrow_array) {
push @ne_id_sz,"$line\n";
my $size=@ne_id_sz;
print  ...


for (my $i=0;$i<@array ;$i++) {
my $s="select ne_id from ne_cell where n_confirm<>1 and ci=$array[$i] and city_id='114' order by 1";
$sth=$dbh->prepare($s);
$sth->execute;
while (my $line=$sth->fetchrow_array) {
push @ne_id_sz,"$line\n";       #每循环一次@ne_id_sz增加保存一个元素,该元素是该次循环的ne_id
my $size=@ne_id_sz;              #这里$size只是取数组元素的个数,因此下面就打印了每次循环的数组元素个数
print $size,"\n";
$sth->finish;
}
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP