免费注册 查看新帖 |

Chinaunix

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

shell如何替换掉excel中的换行符(alt+enter) [复制链接]

论坛徽章:
1
白羊座
日期:2014-11-19 14:18:59
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-10-21 18:00 |只看该作者 |倒序浏览
本帖最后由 鸿钧 于 2010-10-21 18:20 编辑

把excel文件另存为csv文件,导入到linux中处理。如何去掉exce文件中某一单元格中的换行符?

如,我excel中是这样的:

A        B        C
111
222
333        444        555


到linux下变成这样:
vi test.csv:

A,B,C^M
"111
222
333",444,555^M

我如何可以让它恢复成这样:
A,B,C
111 222 33,444,555

论坛徽章:
0
2 [报告]
发表于 2010-10-21 18:23 |只看该作者
本帖最后由 黑色阳光_cu 于 2010-10-21 19:21 编辑

  1. #!/bin/env perl

  2. use strict;
  3. use warnings;
  4. use 5.010;

  5. local $/;
  6. open(my $fp, "<:crlf", "test.csv") or die "test.csv: $!\n";
  7. my $csv = <$fp>;

  8. $csv =~ s{("(?:(?:"")*?|[^"]*?)*?"|[^,"\n]*?)(,|\n)}{my ($tmp, $sp) = ($1, $2); $tmp =~ s/\n/ /g; $tmp . $sp}xeg;
  9. warn $csv;
复制代码
别打我,我是无辜的。

这个,先准确的确定单元格,再把单元格里的\n换成空格,而用来做记录分隔符的\n不会受影响。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2010-10-21 20:30 |只看该作者
dos2unix,tr,sed

论坛徽章:
1
白羊座
日期:2014-11-19 14:18:59
4 [报告]
发表于 2010-10-22 08:47 |只看该作者
能用bash shell实现吗。

想到一个最简单的,在excel中先把所有单元格的“自动换行”去掉,再导出到linux下处理。

论坛徽章:
0
5 [报告]
发表于 2011-01-30 17:39 |只看该作者
dos2unix

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
6 [报告]
发表于 2011-01-31 02:43 |只看该作者
本帖最后由 yinyuemi 于 2011-01-31 03:17 编辑
  1. awk '/\"/{++p}{printf (p%2?$0" ":$0"\n")}'
复制代码
http://bbs3.chinaunix.net/thread-1850730-1-1.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP