免费注册 查看新帖 |

Chinaunix

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

用join拼接字符串有问题,请大侠看看 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-16 10:17 |只看该作者 |倒序浏览
我要把ip.txt的内容读出,再拼接成一条sql语句。但总是只输出ip.txt的内容,不知为什么,请高手指点指点!

!#/usr/bin/perl
open myfile,"ip.txt";

$sqlbegin == "insert into sevencai values(";
$sqlend == ");";

$linetxt = readline myfile;
$newsql = join $sqlbegin,$linetxt,$sqlend;
print $newsql;

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2008-07-16 10:23 |只看该作者
perldoc -f join

论坛徽章:
0
3 [报告]
发表于 2008-07-16 10:24 |只看该作者
不用这么拼接吧,直接就用点号连接就行。

[ 本帖最后由 ermu 于 2008-7-16 10:34 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2008-07-16 10:25 |只看该作者
$newsql = join "$sqlbegin",$linetxt,$sqlend;



EXPR与LIST区分一下

论坛徽章:
0
5 [报告]
发表于 2008-07-16 11:18 |只看该作者
原帖由 zhangkeyijian 于 2008-7-16 10:25 发表
$newsql = join "$sqlbegin",$linetxt,$sqlend;



EXPR与LIST区分一下



不行呀,如果写成$newsql = join “insert into sevencai values(",$linetxt,$sqlend;

打出来就成了  
张三,172.16.10.2
insert into sevencai values(

变成两行输出了

论坛徽章:
0
6 [报告]
发表于 2008-07-16 11:25 |只看该作者
原帖由 ermu 于 2008-7-16 10:24 发表
不用这么拼接吧,直接就用点号连接就行。



也不行,写成$newsql = "insert into sevencai values(".$linetxt.$sqlend;

输出是 insert into sevencai values(张三,172.16.10.2

写成 $newsql = "insert into sevencai values(".$linetxt.“);";

输出是 insert into sevencai values(张三,172.16.10.2
          );
是两行输出

论坛徽章:
0
7 [报告]
发表于 2008-07-16 11:51 |只看该作者
$linetxt = readline myfile;
$linetxt最后有换行符吧,
增加一句chomp($linetxt ),就不会出现换行的情况了吧!

论坛徽章:
0
8 [报告]
发表于 2008-07-16 11:59 |只看该作者
原帖由 Cludy 于 2008-7-16 11:51 发表
$linetxt = readline myfile;
$linetxt最后有换行符吧,
增加一句chomp($linetxt ),就不会出现换行的情况了吧!



好了,谢了!

但为什么用变量拼接有问题呢?

论坛徽章:
0
9 [报告]
发表于 2008-07-16 12:14 |只看该作者
!#/usr/bin/perl
open myfile,"ip.txt";

$sqlbegin = "insert into sevencai values(";
$sqlend = ");";

$linetxt = readline myfile;
chomp($linetxt);

$newsql = join '' ,$sqlbegin,$linetxt,$sqlend;
print $newsql;

试试这样的。
和你的对比一下。。

论坛徽章:
0
10 [报告]
发表于 2008-07-16 13:06 |只看该作者
原帖由 Cludy 于 2008-7-16 12:14 发表
!#/usr/bin/perl
open myfile,"ip.txt";

$sqlbegin = "insert into sevencai values(";
$sqlend = ");";

$linetxt = readline myfile;
chomp($linetxt);

$newsql = join '' ,$sqlbegin,$linetxt,$s ...



不行,这样只能打出 $linetxt
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP