免费注册 查看新帖 |

Chinaunix

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

用shell替换文件中的乱码字符 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-11-18 14:52 |只看该作者 |倒序浏览
本帖最后由 qiujian5628 于 2010-11-18 14:53 编辑

文件有多行记录,其中某些行记录如下:
01|2010-07-26 14:06:13|ë|F
01|2010-07-26 14:06:25|ã|F
01|2010-08-04 15:14:26|ç®Âª¢:j!Š 0
03|^Cs^ZRP?|F
03|2010-11-06 09:48:31|0

我如何替换每一行的乱码字符,使之可以被sqlldr导入数据库中?
我用正则判断,[^0-9,^a-z,^A-Z,^|,^-,^:],可以判断出一些乱码字符,但是ë,ã,Â这样的字符无法准确判断出来,
想过获取每个字符的ascii码值,然后不在0-127之间的都认为是乱码,使用 printf "%d" "'A"能打印出ascii码值,但在shell中如何编写脚本?

论坛徽章:
0
2 [报告]
发表于 2010-11-18 14:59 |只看该作者
查到了如下命令能获取ascii码值
echo a| awk 'BEGIN { for (i=0;i<255;i++) a[sprintf("%c",i)]=i}
{print a[$0]} '

如何结合到shell脚本中实现我的要求?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2010-11-18 15:34 |只看该作者
's/[^[:ascii:]]/target/g'
怎么让sed支持这种写法?

论坛徽章:
0
4 [报告]
发表于 2010-11-18 15:40 |只看该作者
LC_COLLATE=C sed -i 's/[^-,^0-9,^a-z,^A-Z,^[:space:],^|,^:,^@,^.]//g'
这样可以吗?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2010-11-18 15:44 |只看该作者
^只在方括号里面的开头出现才有意义

论坛徽章:
0
6 [报告]
发表于 2010-11-18 16:11 |只看该作者
sed既想全局替换,又想将被替换的原始行输出到某个文件,该如何操作?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
7 [报告]
发表于 2010-11-18 18:50 |只看该作者
sed既想全局替换,又想将被替换的原始行输出到某个文件,该如何操作?
qiujian5628 发表于 2010-11-18 16:11



    用两个sed规则,-e选项指定不同的过滤方式。第一个先打印,接下来的-e才是替换~~

论坛徽章:
0
8 [报告]
发表于 2010-11-19 09:46 |只看该作者
用两个sed规则,-e选项指定不同的过滤方式。第一个先打印,接下来的-e才是替换~~
L_kernel 发表于 2010-11-18 18:50



在同一行中sed -e -e与分开sed -e ,sed -e 效率上有差别吗?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
9 [报告]
发表于 2010-11-19 10:02 |只看该作者
在同一行中sed -e -e与分开sed -e ,sed -e 效率上有差别吗?
qiujian5628 发表于 2010-11-19 09:46



    显然,前面那个快的。shell中fork一个sed,然后sed对应两条过滤规则。后者是要fork两次。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP