位置: 编程技术 - 正文

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)

  • 留底税额有没有时间
  • 职工福利费会计凭证
  • 民营医院一般纳税人帐务处理视频税收风险
  • 代开专用发票需要交城建税吗
  • 税务师2022年考试成绩
  • 工程施工的间接费用怎么结转
  • 代扣代缴增值税纳税义务发生时间
  • 房屋出租收到的租金会计分录
  • 房地产企业消防设施计入什么科目
  • 季报现金流量表是必报表吗
  • 养蜂合作社怎么申请补贴
  • 车间购买灯会计怎么做账
  • 纳税人领购普通发票要求
  • 收到一笔支付宝转账,如何查看转账人
  • 付的押金能要回来吗
  • 会员卡退钱是退全额吗
  • 开票资料电话可以查到吗
  • 服务型企业管理体系
  • 准则大家学第十二集
  • 总公司人员可以在分公司报销费用吗
  • 资本化利息金额
  • 如何刷新手机
  • mac上如何切换apple id
  • 增值税怎么填表
  • 2021工资扣税标准公式
  • imac 5k屏幕参数
  • php加号
  • 政府的奖励金计入哪个科目
  • 事业单位专项经费包括哪些
  • 金融租赁融资融物
  • 企业重组并购条件
  • php java c#
  • 加计扣除的增值税,城建税怎么算
  • 谷歌插件下载网址
  • 库存现金每月终了由谁清点
  • 财务费用利息收入为什么是借方负数
  • 服装加工税率是13%还是16%
  • 外贸企业主要做什么
  • 开具增值税专用发票是什么意思
  • 营业收入的意义是什么
  • 汇兑损益一级科目
  • 工业企业库存商品的初始入账成本
  • 政府扶持资金怎么做账
  • 其他应收款收不回来怎么写情况说明
  • 摊销费用用什么凭证
  • 采购方退货的会计分录
  • 上月暂估本月怎么冲销
  • 利润分享并购方法有哪些
  • 红字的记账凭证怎么记账
  • 租房公司报销发票怎么开
  • 子公司利润母公司还有其他方式吗
  • 凭证扣除 28号
  • 营改增 交通运输
  • 会计错账更正方法口诀
  • 工资完税证明怎么开
  • java开发经常出差合理吗
  • Kali(debian) Too many open files 错误处理办法
  • Windows 7(x64)下安装Ubuntu12.4的方法
  • windows 11安全模式
  • win8.1怎么用
  • win10右下角的图标点不开
  • linux指定格式显示日期
  • win7插上u盘显示格式化怎么办
  • win8.1怎么样
  • 升级win10系统卡住不动了
  • edit apps
  • linux tcp keepalive
  • cocos 2.5d
  • cocos2dx ui编辑器
  • div-css
  • unity转盘游戏
  • linux搭载服务器
  • javascript简明教程
  • javascript中var的作用
  • 工具类别怎么填写
  • 安卓手机管家怎么关闭
  • 江苏电子税务局网站官网
  • 经济补偿金如何计税
  • 珠海市高新区国土局局长
  • 企业分立需要开发票吗?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设