一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Linux|Centos|Ubuntu|系統進程|Fedora|注冊表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服務器之家 - 服務器系統 - Linux - Linux下將UTF8編碼批量轉換成GB2312編碼的方法

Linux下將UTF8編碼批量轉換成GB2312編碼的方法

2019-10-24 19:27Linux教程網 Linux

在sqlplus中導入UTF8編碼的sql腳本就會出現亂碼錯誤,這時就需要將UTF8編碼轉換成GB2312編碼,下面為大家介紹下在Linux下如何進行轉換

UTF8編碼GB2312編碼是有區別的,在sqlplus中導入UTF8編碼的sql腳本就會出現亂碼錯誤,這時就需要將UTF8編碼轉換成GB2312編碼,可是一個個的轉換十分麻煩,下面小編就教你如何在Linux下將UTF8編碼批量轉換成GB2312編碼。

Linux下將UTF8編碼批量轉換成GB2312編碼的方法

  背景

  本人在使用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_utf810. if grep ‘^\\357\\273\\277’ $file_check_utf8 》/dev/null 2》&111. then

  echo ‘UTF-8 BOM’

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

  rm -rf $loop.tmp

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

  echo ‘UTF-8’

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

  else

  echo ‘ANSI’

  mv -f $loop.tmp $loop

  fi

  rm -rf $file_check_utf8

  #模擬unix2dos,要求文本文件最后一行必須有換行符28. sed -n -e ‘s/$/\r/g’ -e ‘w ’$loop.tmp $loop29. 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_utf810. if grep ‘^\\357\\273\\277’ $file_check_utf8 》/dev/null 2》&111. then

  echo ‘UTF-8 BOM’

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

  rm -rf $loop.tmp

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

  echo ‘UTF-8’

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

  else

  echo ‘ANSI’

  mv -f $loop.tmp $loop

  fi

  rm -rf $file_check_utf8

  #模擬unix2dos,要求文本文件最后一行必須有換行符28. sed -n -e ‘s/$/\r/g’ -e ‘w ’$loop.tmp $loop29. mv -f $loop.tmp $loop

  done

  解釋

  1.處理UTF8的BOM,本人沒有找到好的辦法,最后用sed+grep判斷了一下,如果前三個字節是\\357\\273\\277,則文件必定是UTF8,用sed去掉這三個字節再轉換

  2.為了避免重復或者遺漏,腳本中用iconv對沒有BOM的文件嘗試轉換了一把,轉換成功說明文件是UTF8,否則說明是ANSI也就是GB2312

  3.關于最后的sed命令,那是因為本人的系統上沒有unix2dos命令,所以進行了模擬,目的是為了方便自己在windows下查看和編輯

  以上就是Linux下將UTF8編碼批量轉換成GB2312編碼的方法介紹了,轉換后就能解決亂碼等問題,可使用命令鏡像批量轉換,你學會了嗎?

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 天美传媒影视在线免费观看 | 精品国内自产拍在线视频 | 欧美一级久久久久久久大片 | 帅老头恋帅老头同性tv | 精品免费tv久久久久久久 | 性xxx免费| 亚洲精品专区 | 精品国产免费第一区二区 | 80s在线| 俄罗斯激情性孕妇孕交大全 | 深夜在线 | 日本韩国推理片免费观看网站 | 草嫩社区 | 久久精品成人免费看 | 国产未成女年一区二区 | 青柠在线完整高清观看免费 | 免费一级欧美大片在线观看 | 好姑娘在线观看完整版免费 | 我和么公的秘密小说免费 | 免费观看国产视频 | 国产精品毛片高清在线完整版 | 国产精品香蕉一区二区三区 | 无人区在线观看免费视频国语 | 湿好紧太硬了我太爽了 | 美女张开腿黄网站免费精品动漫 | 姐姐不~不可以动漫在线观看 | 调教扩张宫颈女人惨叫 | 天美传媒tm0087 | 九九久久国产精品免费热6 九九精品视频一区二区三区 | 国产成人91高清精品免费 | 日韩一区国产二区欧美三 | 我把校花黑色蕾丝胸罩脱了 | 国产成人手机在线好好热 | 久久精品午夜一区二区福利 | 天天草人人草 | 日韩天堂视频 | 日日爽| 岛国在线播放v片免费 | 久久精品在现线观看免费15 | 欧美在线国产 | 欧美兽皇video |