免费注册 查看新帖 |

Chinaunix

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

求助:在字符串中插入字符串!! [复制链接]

论坛徽章:
26
CU十二周年纪念徽章
日期:2013-10-24 15:41:34技术图书徽章
日期:2014-07-11 16:27:52辰龙
日期:2014-09-04 13:40:43白羊座
日期:2014-09-09 12:51:55双子座
日期:2014-09-26 11:00:042014年中国系统架构师大会
日期:2014-10-14 15:59:00子鼠
日期:2014-10-23 16:48:23巨蟹座
日期:2014-10-27 08:21:10申猴
日期:2014-12-08 10:16:282015年辞旧岁徽章
日期:2015-03-03 16:54:15NBA常规赛纪念章
日期:2015-05-04 22:32:03IT运维版块每日发帖之星
日期:2016-01-29 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-10-08 12:17 |只看该作者 |倒序浏览
20可用积分
本来是在mysql版块放的,但好象mysql不能单独完成
所以放到php来

请各位有空的高手帮一下忙!

求助:mysql 字段中插入字符串!!
查询:
select  aaa from table where id = '1'
得到如下:
1|a|b|c|d|\r\n2|q|w|e|r|\r\n3|a|s|d|f|\r\n

现要
在每个\r\n前的第2个|后插入|||

要得到
1|a|b|c||||d|\r\n2|q|w|e||||r|\r\n3|a|s|d||||f|\r\n

请问一下,如何可实现

谢谢了!

最佳答案

查看完整内容

不知这样是否符合要求?

论坛徽章:
0
2 [报告]
发表于 2009-10-08 12:17 |只看该作者
#!/usr/bin/php
<?php

function transform($input)
{
        $prcessed = array();

        $lines = explode("\r\n", $input);

        foreach($lines as $line)
        {
                if($line == "")
                {
                        continue;
                }

                $pattern = "/\|[^\|]+\|$/";

                $newline = preg_replace($pattern, "|||$0", $line);

                $prcessed[] = $newline;

        }

        //print_r($prcessed);


        $output = join($prcessed, "\r\n")."\r\n";

        return $output;
}

$result = transform("1|a|b|c|d|\r\n2|q|w|e|r|\r\n3|a|s|d|f|\r\n");

echo $result;

?>


不知这样是否符合要求?

论坛徽章:
26
CU十二周年纪念徽章
日期:2013-10-24 15:41:34技术图书徽章
日期:2014-07-11 16:27:52辰龙
日期:2014-09-04 13:40:43白羊座
日期:2014-09-09 12:51:55双子座
日期:2014-09-26 11:00:042014年中国系统架构师大会
日期:2014-10-14 15:59:00子鼠
日期:2014-10-23 16:48:23巨蟹座
日期:2014-10-27 08:21:10申猴
日期:2014-12-08 10:16:282015年辞旧岁徽章
日期:2015-03-03 16:54:15NBA常规赛纪念章
日期:2015-05-04 22:32:03IT运维版块每日发帖之星
日期:2016-01-29 06:20:00
3 [报告]
发表于 2009-10-08 16:54 |只看该作者
非常正确,谢谢!

问题得到完美的解决!

我还要问一下
如果是
在每个\r\n前的第  3  个|后插入|||   (把2改成了3)

我应按在哪里做相应的修改可用

谢谢

论坛徽章:
0
4 [报告]
发表于 2009-10-09 09:32 |只看该作者

回复 #3 cryboy2001 的帖子

把$pattern改成
$pattern = "/\|[^\|]+\|[^\|]+\|$/";
或者
$pattern = "/(\|[^\|]+){2}\|$/";
这样就可以了

[ 本帖最后由 mike_possible 于 2009-10-9 09:45 编辑 ]

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
5 [报告]
发表于 2009-10-22 15:33 |只看该作者
用正则表达式是最快的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP