忘记密码   免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 认证专区 大话IT 徽章 文库 自测 下载 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 1276 | 回复: 4

[文本处理] echo和while read line 的IFS 怎么没法配合使用呢? [复制链接]

论坛徽章:
2
15-16赛季CBA联赛之辽宁
日期:2017-12-28 12:15:1015-16赛季CBA联赛之福建
日期:2017-12-28 12:26:51
发表于 2017-12-30 03:40 |显示全部楼层
[oracle@rac2 script]$ echo '123,234,345' | while IFS=, read V1; do echo $V1; done
123,234,345

论坛徽章:
32
荣誉会员
日期:2011-11-23 16:44:17射手座
日期:2014-09-03 16:01:17天蝎座
日期:2014-08-21 17:18:48丑牛
日期:2014-08-29 16:06:45天秤座
日期:2014-08-29 10:12:18天秤座
日期:2014-08-26 16:18:20双子座
日期:2014-07-30 11:38:27寅虎
日期:2014-08-04 10:24:12IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
发表于 2017-12-30 13:03 |显示全部楼层
回复 1# XQKA

  1. echo '123,234,345,' | while read -d',' V1; do echo $V1; done
复制代码

论坛徽章:
2
15-16赛季CBA联赛之辽宁
日期:2017-12-28 12:15:1015-16赛季CBA联赛之福建
日期:2017-12-28 12:26:51
发表于 2018-01-02 11:13 |显示全部楼层
[root@Dev-Mysql .script]# echo '123,234,345' | while read -d',' V1; do echo $V1; done
123
234

少最后一个域

我的处理方法:
[root@Dev-Mysql .script]# echo '123,234,345' | sed s/,/\\n/g |
> while read V1
> do
> echo $V1
> done
123
234
345

论坛徽章:
3
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之同曦
日期:2017-09-11 14:39:482016科比退役纪念章
日期:2018-01-19 12:45:59
发表于 2018-01-03 12:08 |显示全部楼层
本帖最后由 wh7211 于 2018-01-03 12:12 编辑

回复 1# XQKA


你的写法没问题,IFS是已经生效的:
  1. echo '123,234,345' | while IFS=, read V1; do echo $V1; done
复制代码

输出:
123,234,345

  1. echo '123,234,345' | while IFS=, read V1 V2; do echo $V1:$V2; done
复制代码

输出:
123:234,345

  1. echo '123,234,345' | while IFS=, read V1 V2 V3; do echo $V1:$V2:$V3; done
复制代码

输出:
123:234:345

论坛徽章:
0
发表于 2018-01-03 14:43 |显示全部楼层
powershell语法容易,毕竟是10年前出的,bash语法太老,或许不简便了:

$a = '123,234,345' -split ','
$a[0] #返回123

$b,$c,$d = '123,234,345' -split ','
$b #返回123

python语法也不错,不过(≈)没有管道和命令行。

您需要登录后才可以回帖 登录 | 注册

本版积分规则

DTCC2018购票6.8折优惠进行时

中国数据库技术大会是国内数据库及大数据领域规模最大、最受欢迎的技术交流盛会。 2018年5月10-12日,第九届中国数据库技术大会将如约而至。本届大会以“数领先机•智赢未来”为主题,设定2大主会场及20个技术专场,邀请来自国内外互联网、金融、教育等行业百余位技术专家,共同探讨Oracle、MySQL、NoSQL、大数据等领域的前瞻性热点话题与技术。
----------------------------------------
优惠时间:2018年2月13日前

报名链接>>
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号 北京市公安局海淀分局网监中心备案编号:11010802020122
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP