免费注册 查看新帖 |

Chinaunix

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

高手们快来!! [复制链接]

论坛徽章:
0
11 [报告]
发表于 2006-07-11 09:21 |只看该作者
awk -v FIELDWIDTHS="8 9 20 20" '$2~/[0-9]/{print $0" in"}$3~"[0-9]"{print $0" out"}' your-file 出来的文件和原来的一样没变呢?

论坛徽章:
0
12 [报告]
发表于 2006-07-11 10:09 |只看该作者
用vi

%s/ \{20,\}/                /g
%s/ \{1,\}/        /g

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
13 [报告]
发表于 2006-07-11 10:21 |只看该作者
用execl导入时不能定义列宽度么?

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
14 [报告]
发表于 2006-07-11 16:37 |只看该作者
原帖由 bnls023 于 2006-7-11 09:21 发表
awk -v FIELDWIDTHS="8 9 20 20" '$2~/[0-9]/{print $0" in"}$3~"[0-9]"{print $0" out"}' your-file 出来的文件和原来的一样没变呢?

真的一样吗?再仔细看看。^_^我只是举个例子说明可以按宽度划分字段而已,不过既然已经按字段取得数字,其它的有什么难的?下面的输出结果可以么:
awk -v FIELDWIDTHS="8 9 20 20" '/[0-9]/{$2+=0;$3+=0;$4+=0;print}'
其实这里我们只是讨论shell工具的功能。如楼上waker所说的:不用额外处理,excel就能导入你的文件。

论坛徽章:
0
15 [报告]
发表于 2006-07-12 09:09 |只看该作者
我只要打比方用excel导入,实质是想导入数据库,能区分借贷方发生额,所以有难度了.....

论坛徽章:
0
16 [报告]
发表于 2006-07-12 09:17 |只看该作者
也就是假如是这样的文本在导入的时候能把借贷方区分出来.如果去除空格后借和贷就合并在一起了,
日期   借  贷 余额
02      10      20
03          20  30
04      20      50
06          10  60

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
17 [报告]
发表于 2006-07-12 09:50 |只看该作者
你的数据有规律么?如果每个字段长度是固定的,建议读10楼回复至解决,cut和awk的方案原理都是一样的

如果没有规律建议手动解决/雇人解决/换人解决

论坛徽章:
0
18 [报告]
发表于 2006-07-12 10:36 |只看该作者
哪大家帮我想想怎么能够左对齐?这样就可以用cut了.

论坛徽章:
0
19 [报告]
发表于 2006-07-12 11:37 |只看该作者
如果楼主非要用shell来解决,那我不会。
用excel直接打开导入时用固定宽度的办法就可以了。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
20 [报告]
发表于 2006-07-12 15:34 |只看该作者
跟楼主沟通起来还真是有点吃力!^_^
1.数据究竟是什么样的,如果与楼顶贴出的有出入,请贴上来哪怕是只有几行“活的”也行。不一定要每个字段长度一定,只要可以通过字符的个数来区分不同的字段,那就容易了。
2.楼主似乎是SCO平台,如果安装了GNU awk,才能使用"FIELDWIDTHS="8 9 20 20"的语法,那样你把4楼和14楼的代码一试就明白了。如果没有GNU awk,我们还是别纸上谈兵扯不清了,换其它方法罢。
3.如果有perl,用正则+替换,写起来比Sed简单清楚些:
perl -pe 's/(.{8})(.{9})(.{20})/\1,\2,\3,/ if /\d/'
4.用sed,类似这样:
sed '/[0-9]/s/\(.\{8\}\)\(\{9\}\)\(\{20\}\)/\1,\2,\3,/'
5.cut -c的方法,原理一样。我就不写了。
不晓得楼主最后怎样使用数据,不过经过上面的代码预处理过后应该都没有大的问题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP