濮阳杆衣贸易有限公司

主頁 > 知識庫 > linux系統(tǒng)下批量轉(zhuǎn)換UTF8到GB2312并處理UTF8的BOM標記

linux系統(tǒng)下批量轉(zhuǎn)換UTF8到GB2312并處理UTF8的BOM標記

熱門標簽:營業(yè)廳外呼系統(tǒng)有錄音嗎 地圖標注和視頻彩鈴制作生意 宿松百度地圖標注 南京電銷外呼系統(tǒng)廠家 地圖標注怎么兼職 南通電銷外呼系統(tǒng)排名 滁州外呼系統(tǒng)接口對接 信陽智能外呼系統(tǒng)聯(lián)系方式 合力億捷外呼系統(tǒng)如何解壓安裝

  背景

  本人在使用oracle的sqlplus批量導入UTF8編碼的sql腳本時,由于不了解如何設置讓sqlplus識別UTF8格式,導致出現(xiàn)亂碼、錯行等錯誤,而使工作無法繼續(xù),在google無果的情況下只好想辦法轉(zhuǎn)換編碼。

  由于文件較多,手動轉(zhuǎn)換太麻煩,于是想到用腳本批量轉(zhuǎn)換,幸好網(wǎng)上相關腳本比較多,實現(xiàn)起來唯一的麻煩是UTF8的BOM標記。

  內(nèi)容:


復制代碼
代碼如下:
  #!/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判斷了一下,如果前三個字節(jié)是\\357\\273\\277,則文件必定是UTF8,用sed去掉這三個字節(jié)再轉(zhuǎn)換

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

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

  以上就是linux 批量轉(zhuǎn)換UTF8到GB2312并處理UTF8的BOM標記 的方法,謝謝閱讀,希望能幫到大家,請繼續(xù)關注腳本之家,我們會努力分享更多優(yōu)秀的文章。

標簽:保定 山南 衢州 麗水 新余 銅陵 潛江 運城

巨人網(wǎng)絡通訊聲明:本文標題《linux系統(tǒng)下批量轉(zhuǎn)換UTF8到GB2312并處理UTF8的BOM標記》,本文關鍵詞  linux,系統(tǒng),下,批量,轉(zhuǎn)換,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《linux系統(tǒng)下批量轉(zhuǎn)換UTF8到GB2312并處理UTF8的BOM標記》相關的同類信息!
  • 本頁收集關于linux系統(tǒng)下批量轉(zhuǎn)換UTF8到GB2312并處理UTF8的BOM標記的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    北京市| 庆安县| 吉安县| 和顺县| 仪征市| 诏安县| 利辛县| 德清县| 沈阳市| 黎城县| 区。| 邓州市| 延津县| 子洲县| 永城市| 贵溪市| 和硕县| 梅河口市| 温宿县| 镇原县| 天祝| 屏东县| 苗栗市| 呼图壁县| 贡嘎县| 法库县| 临夏市| 库伦旗| 武鸣县| 邯郸市| 荔波县| 娱乐| 辰溪县| 宜阳县| 天气| 共和县| 凤翔县| 高邮市| 竹北市| 霍林郭勒市| 岑巩县|