免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
论坛 程序设计 Shell 请教
12下一页
最近访问板块 发新帖
查看: 1769 | 回复: 11
打印 上一主题 下一主题

请教 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-03-08 23:27 |只看该作者 |倒序浏览
1   2   23   8
8       9    3
    3   3
5            4

如何将无数的地方补0?

论坛徽章:
7
荣誉版主
日期:2011-11-23 16:44:17子鼠
日期:2014-07-24 15:38:07狮子座
日期:2014-07-24 11:00:54巨蟹座
日期:2014-07-21 19:03:10双子座
日期:2014-05-22 12:00:09卯兔
日期:2014-05-08 19:43:17卯兔
日期:2014-08-22 13:39:09
2 [报告]
发表于 2005-03-08 23:30 |只看该作者

请教

  1. tr ' ' 0
复制代码

论坛徽章:
0
3 [报告]
发表于 2005-03-08 23:55 |只看该作者

请教

误会,应该是
1   2   23   8
8   0    9   3
0   3    3   0
5   0    0   4

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
4 [报告]
发表于 2005-03-09 00:03 |只看该作者

请教

至少要有一些规律吧!

论坛徽章:
0
5 [报告]
发表于 2005-03-09 14:36 |只看该作者

请教

不知道这样满足你的要求吗???
/tpv/mis/ms20499/study/shfile/sh_sh/awk_sed/g>cat a.txt
1   2   23   8
8       9    3
    3   3
5            4
#!/bin/sh
cut -c 1,2 a.txt |awk '{var=$1;if(var=="" print "0";else print var}' >a
cut -c 4,5 a.txt |awk '{var=$1;if(var=="" print "0";else print var}' >b
cut -c 9,10 a.txt |awk '{var=$1;if(var=="" print "0";else print var}' >c
cut -c 12,14 a.txt |awk '{var=$1;if(var=="" print "0";else print var}' >d
paste a b c d | cat
rm a b c d
/tpv/mis/ms20499/study/shfile/sh_sh/awk_sed/g>sh a.sh
1       2       23      8
8       0       9       3
0       3       3       0
5       0       0       4

论坛徽章:
0
6 [报告]
发表于 2005-03-09 16:54 |只看该作者

请教

谢谢楼上的,辛苦了。
其实这也是别人问我的一个问题,他的数据在excell里,数据量很大,我只是举了个列子。所以如果按楼上的来实现好象不大现实。
他后来在excell里用替换实现了,用0替换空白就好了。想知道shell能不能比较简单的实现,因为这个问题还是比较普遍的。

论坛徽章:
0
7 [报告]
发表于 2005-03-09 16:57 |只看该作者

请教

重了  

论坛徽章:
0
8 [报告]
发表于 2005-03-09 20:04 |只看该作者

请教

用零替换空格?那它在excell里无数据的单元格内都有空格吗?
既然可以逐个输入空格,为什么不直接输入0?

论坛徽章:
0
9 [报告]
发表于 2005-03-09 21:13 |只看该作者

请教

至少你的空格数量应该有规律吧

论坛徽章:
0
10 [报告]
发表于 2005-03-09 23:38 |只看该作者

请教

原帖由 "coldrain2929" 发表:
用零替换空格?那它在excell里无数据的单元格内都有空格吗?
既然可以逐个输入空格,为什么不直接输入0?

在excell的单元格是什么也没有输入,他的数据本来就在excell里的,是0的地方压根就没有输。然后用excell中的替换就可以了。

如果相用shell的话就把另存为txt格式的,就想我举的列子那样了。

要说规律吗就是每一列如果有数据就是数字,没数据就是空格
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP