婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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)民參考!
  • 推薦文章
    主站蜘蛛池模板: 阿城市| 淅川县| 上杭县| 沙雅县| 柳江县| 丹棱县| 安乡县| 金溪县| 盐城市| 彰化县| 镇赉县| 大新县| 祁东县| 沁源县| 常德市| 焦作市| 江山市| 遵义县| 云梦县| 泸定县| 庆阳市| 方城县| 新绛县| 铁力市| 大兴区| 红原县| 昌图县| 财经| 巫山县| 逊克县| 台安县| 万全县| 上蔡县| 长治市| 英山县| 城口县| 龙南县| 南宁市| 西宁市| 红原县| 甘肃省|