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

主頁 > 知識庫 > linux系統下批量轉換UTF8到GB2312并處理UTF8的BOM標記

linux系統下批量轉換UTF8到GB2312并處理UTF8的BOM標記

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

  背景

  本人在使用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并處理UTF8的BOM標記 的方法,謝謝閱讀,希望能幫到大家,請繼續關注腳本之家,我們會努力分享更多優秀的文章。

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

巨人網絡通訊聲明:本文標題《linux系統下批量轉換UTF8到GB2312并處理UTF8的BOM標記》,本文關鍵詞  linux,系統,下,批量,轉換,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《linux系統下批量轉換UTF8到GB2312并處理UTF8的BOM標記》相關的同類信息!
  • 本頁收集關于linux系統下批量轉換UTF8到GB2312并處理UTF8的BOM標記的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 富民县| 孟津县| 金寨县| 沈丘县| 延安市| 金华市| 孟州市| 宜宾县| 定襄县| 塔河县| 贺州市| 泗阳县| 鄂尔多斯市| 南乐县| 罗定市| 宁陕县| 甘泉县| 抚顺县| 汉中市| 清徐县| 清镇市| 贡嘎县| 伊金霍洛旗| 错那县| 上虞市| 瑞昌市| 黄梅县| 聂荣县| 闻喜县| 沅陵县| 盐津县| 屯昌县| 扶沟县| 永宁县| 广南县| 大化| 乐业县| 洛浦县| 龙井市| 阿克苏市| 东乡|