位置: 编程技术 - 正文

Linux下将UTF8编码批量转换成GB2312编码的方法(linux设置utf8编码)

编辑:rootadmin

推荐整理分享Linux下将UTF8编码批量转换成GB2312编码的方法(linux设置utf8编码),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux utf8,linux 转码为utf8,linux设置编码为utf-8,linux将utf8转换为gbk,linux设置utf8编码,linux的utf8转码gbk,linux utf8,linux utf8,内容如对您有帮助,希望把文章链接给更多的朋友!

  UTF8编码和GB编码是有区别的,在sqlplus中导入UTF8编码的sql脚本就会出现乱码错误,这时就需要将UTF8编码转换成GB编码,可是一个个的转换十分麻烦,下面小编就教你如何在Linux下将UTF8编码批量转换成GB编码。

  背景

  本人在使用oracle的sqlplus批量导入UTF8编码的sql脚本时,由于不了解如何设置让sqlplus识别UTF8格式,导致出现乱码、错行等错误,而使工作无法继续,在google无果的情况下只好想办法转换编码。

  由于文件较多,手动转换太麻烦,于是想到用脚本批量转换,幸好网上相关脚本比较多,实现起来唯一的麻烦是UTF8的BOM标记。

  内容:

  代码如下:

  #!/bin/bash

  for loop in `find 。 -type f -name “*.sql” -print`do

  echo $loop

  mv -f $loop $loop.tmp

  dos2unix $loop.tmp

  file_check_utf8=‘file_check_utf8.log’

  sed -n ‘1l’ $loop.tmp 》$file_check_utf. if grep ‘^\\\’ $file_check_utf8 》/dev/null 2》&. then

  echo ‘UTF-8 BOM’

  sed -n -e ‘1s/^.。。//’ -e ‘w intermediate.txt’ $loop.tmp. iconv -f UTF-8 -t GB -o $loop intermediate.txt. rm -rf intermediate.txt

  rm -rf $loop.tmp

  elif iconv -f UTF-8 -t GB $loop.tmp 》/dev/null 2》&. then

  echo ‘UTF-8’

  iconv -f UTF-8 -t GB -o $loop $loop.tmp. rm -rf $loop.tmp

  else

  echo ‘ANSI’

  mv -f $loop.tmp $loop

  fi

Linux下将UTF8编码批量转换成GB2312编码的方法(linux设置utf8编码)

  rm -rf $file_check_utf8

  #模拟unix2dos,要求文本文件最后一行必须有换行符. sed -n -e ‘s/$/r/g’ -e ‘w ’$loop.tmp $loop. mv -f $loop.tmp $loop

  done

  #!/bin/bash

  for loop in `find 。 -type f -name “*.sql” -print`do

  echo $loop

  mv -f $loop $loop.tmp

  dos2unix $loop.tmp

  file_check_utf8=‘file_check_utf8.log’

  sed -n ‘1l’ $loop.tmp 》$file_check_utf. if grep ‘^\\\’ $file_check_utf8 》/dev/null 2》&. then

  echo ‘UTF-8 BOM’

  sed -n -e ‘1s/^.。。//’ -e ‘w intermediate.txt’ $loop.tmp. iconv -f UTF-8 -t GB -o $loop intermediate.txt. rm -rf intermediate.txt

  rm -rf $loop.tmp

  elif iconv -f UTF-8 -t GB $loop.tmp 》/dev/null 2》&. then

  echo ‘UTF-8’

  iconv -f UTF-8 -t GB -o $loop $loop.tmp. rm -rf $loop.tmp

  else

  echo ‘ANSI’

  mv -f $loop.tmp $loop

  fi

  rm -rf $file_check_utf8

  #模拟unix2dos,要求文本文件最后一行必须有换行符. sed -n -e ‘s/$/r/g’ -e ‘w ’$loop.tmp $loop. mv -f $loop.tmp $loop

  done

  解释

  1.处理UTF8的BOM,本人没有找到好的办法,最后用sed+grep判断了一下,如果前三个字节是\\\,则文件必定是UTF8,用sed去掉这三个字节再转换

  2.为了避免重复或者遗漏,脚本中用iconv对没有BOM的文件尝试转换了一把,转换成功说明文件是UTF8,否则说明是ANSI也就是GB

  3.关于最后的sed命令,那是因为本人的系统上没有unix2dos命令,所以进行了模拟,目的是为了方便自己在windows下查看和编辑

  

标签: linux设置utf8编码

本文链接地址:https://www.jiuchutong.com/biancheng/367648.html 转载请保留说明!

上一篇:Linux下利用PC机进行路由转发将Linux变成一台路由器(使用linux的电脑)

下一篇:Linux下清除文件中的隐私数据以保护个人隐私(清除文件内容 linux)

  • 税前弥补亏损是净利润吗
  • 没房分手的多吗
  • 预算资产负债表
  • 如何做好服务 服务行业
  • 费用已付发票未到的预算会计分录
  • 电子记账软件出纳帐
  • 营改增的增值税
  • 房产未竣工如何缴纳房产税
  • 现金日记账是收付实现制吗
  • 长期借款账务处理会计分录例题
  • 股息红利税补缴什么意思
  • 印花税账务处理
  • 公司借款给个人利息怎么做账
  • 跨年度取得增值税发票
  • 广告制作费有哪些项目
  • 应交增值税明细科目如何结转
  • 个人所得税是次月申报上月的吗怎么填
  • 把黑龙江省
  • 银行代发工资当月没发下个月发没事儿吧
  • 委托加工费的增值税计入成本吗
  • 出口外贸海运费的会计处理
  • 税务非正常户罚款多少
  • 本期金额怎么计算
  • 进项票认证超了怎么处理
  • 税率税额是星号什么意思
  • 支付征地补偿款怎么开具增值税发票
  • 资金拆借需防范哪些风险
  • 分公司的股东怎么填
  • php vld
  • 记账凭证填制的依据
  • 赞助支出计入应纳税所得额吗
  • 定额征收的个体户怎么做账
  • 委托贷款业务是资产业务吗
  • ChatGPT遭禁用、抵制后又停止Plus付费发生了?
  • 专票电话号码不对有影响吗
  • 临时工享受的福利有哪些
  • 抵押房产的保险费
  • 厂家给的返点怎么下往来账
  • 织梦怎么调用当前栏目下的文章
  • 消防设备计入什么科目
  • 劳务报酬是自行缴纳吗
  • 公司向员工发放的慰问金怎么做账
  • 支付运费的会计怎么记录运输费
  • 可供出售金融资产名词解释
  • 货物已到发票未开具
  • 小企业营业外支出的内容
  • 外币报表折算差额名词解释
  • 发票开预付卡充值可以计入费用吗?
  • 负债类科目分录
  • 应交税费期初有余额吗
  • 拆除费计入哪个科目
  • vs2010安装失败的解决办法
  • 数据结构 简书
  • windows延缓写入失败怎么修复
  • win10预览版21301bug
  • 安装完xp系统直接蓝屏怎么办
  • linux怎么用命令
  • docker安装位置
  • dyservice.exe是什么
  • centos7网络配置文件在哪
  • nb3是什么文件
  • win7怎么打开windows media player
  • linux硬盘io
  • css教程笔记
  • ext.grid.gridpanel
  • 深入浅出讲解es63
  • jquery 动态加载js
  • cmd读取d盘
  • python的类变量和成员变量
  • javascript快速入门
  • 键盘事件有三个 分别是
  • bootstrap基础教程
  • 组件中js可以做什么
  • 十万元版增值税税率13发票最高开多少
  • 增值税进项发票如何做账
  • 医院盖章去哪个部门
  • 进项名称和销项同一产品不同称呼
  • 浙江省国税局地址
  • 什么是增值税税率是多少
  • 国税总局17号公告
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设