位置: 编程技术 - 正文

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)

  • 物业公司增值税加计扣除
  • 个税扣除方法叫什么
  • 从租计征房产税低于从价计征房产税
  • CIA是指什么会计考试
  • 涉税业务有哪些
  • 盘盈的固定资产怎么做账务处理
  • 公积金个人缴纳多少
  • 其他应收款利息收入会计分录怎么写
  • 增值税专用发票和普通发票的区别
  • 纳税人转登记期限
  • 土地增值税清算利息扣除规定
  • 收票据计息利息为什么要红字冲账?
  • 应收账款贷方余额表示什么
  • 商贸运费核算到几号结束
  • 工会经费计税依据是应发工资还是实发工资
  • 税收缴款书怎么做凭证
  • 国家税务总局2017 11号
  • 3%小规模纳税人开出的发票 农产品成本如何计算
  • 所得税汇算清缴退款账务处理
  • 收到老板的钱会计分录
  • 金蝶kis标准版软件操作流程演示
  • 发票拍照打印出来不清晰
  • 手动设定ip地址后连不上网
  • 将原材料变成成品的过程
  • 职工福利费的构成
  • 长期借款利息如何做账
  • 公司为员工购买社保流程
  • php utf8转unicode
  • iis防盗链
  • 固定资产转让税金怎么算
  • 金融企业存出保函的条件
  • 建筑增值税税率变化
  • 固定资产提前报废
  • 暂估入库的商品含税吗
  • tokenall
  • vue全局引入js文件
  • php execute函数
  • 汽车以旧换新怎么操作
  • 帝国cms功能
  • 补交上年所得税怎么调表
  • 勾选认证发票的时候找不到这张发票号码怎么办
  • 产生滞纳金有什么影响
  • 0申报残保金逾期影响企业信用评级吗为什么
  • mongodb 统计
  • 向境外股东分配股息预提所得税
  • 非盈利机构怎么说
  • SqlServer 2005/2008数据库被标记为“可疑”的解决办法
  • 财产清查两种制度
  • 集团内部借款利率如何确定
  • 房屋装修费计入长期待摊费用
  • 在职职工暖气费补助款
  • 亏损企业对外捐赠的税前扣除
  • 收汇结汇以什么汇率入账
  • 二手车公司销售二手车增值税怎么算
  • 投资款如何界定
  • 公摊水电费计入什么科目
  • 贷款公司如何确定利率
  • 资产减值损失结转到本年利润吗
  • 企业会计的应用指南
  • 账簿凭证的管理要求
  • mysql索引的使用和原理
  • wins9
  • win8.1电脑设置在哪里
  • windows越狱软件
  • windows8使用技巧
  • win10应用商店叫什么
  • win10怎么这只让任务栏图标居中显示?
  • 在机上创建一个文件夹
  • unity开发的小游戏
  • nodejs客户端框架
  • 如何ssh登陆
  • Node.js中的全局对象有
  • 魅蓝notezol
  • linux使用文本编辑器
  • c#委托的理解
  • HTTP状态代码以及定义(解释)
  • pythonsetter
  • 河南税务局退税流程
  • 诺诺发票怎样上报汇总
  • 潍坊市市区
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设