9久久伊人精品综合,亚洲一区精品视频在线,成 人免费va视频,国产一区二区三区黄网,99国产精品永久免费视频,亚洲毛片多多影院,精品久久久无码人妻中文字幕,无码国产欧美一区二区三区不卡
學習啦>學習電腦>操作系統>Linux教程>

Linux下如何將UTF8編碼批量轉換成GB2312編碼

時間: 孫勝龍652 分享

  UTF8編碼和GB2312編碼是有區別的,在sqlplus中導入UTF8編碼的sql腳本就會出現亂碼錯誤,這時就需要將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 ‘^737’ $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 ‘^737’ $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判斷了一下,如果前三個字節是737,則文件必定是UTF8,用sed去掉這三個字節再轉換

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

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

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

Linux下如何將UTF8編碼批量轉換成GB2312編碼

UTF8編碼和GB2312編碼是有區別的,在sqlplus中導入UTF8編碼的sql腳本就會出現亂碼錯誤,這時就需要將UTF8編碼轉換成GB2312編碼,可是一個個的轉換十分麻煩,下面學習啦小編就教你如何在Linux下將UTF8編碼批量轉換成GB2312編碼。 背景 本
推薦度:
點擊下載文檔文檔為doc格式

精選文章

  • Linux系統中head命令如何使用
    Linux系統中head命令如何使用

    當我們需要查看文件的頭部的時候,就要用到head命令,head命令主要用來查看文件前幾行或多少字節的內容,下面隨學習啦小編一起來了解下Linux下head命令

  • Linux下如何使用tail命令
    Linux下如何使用tail命令

    如果head命令用于查看文件的頭部,那么tail命令就正好相反,tail命令主要用于查看文件內容的結尾,下面學習啦小編就給大家詳細介紹下Linux下tail的用法吧

  • Linux中which命令怎么查找文件
    Linux中which命令怎么查找文件

    現如今,人們的工作中已經離不開電腦的運用,當然電腦的運行離不開操作系統。那么,關于操作系統的一些問題,Linux中which命令怎么查找文件呢?學習啦

  • Linux如何對網站數據進行自動備份和刪除
    Linux如何對網站數據進行自動備份和刪除

    現如今,人們的工作中已經離不開電腦的運用,當然電腦的運行離不開操作系統。那么,關于操作系統的一些問題,Linux如何對網站數據進行自動備份和刪

307874 主站蜘蛛池模板: 国产无遮挡猛进猛出免费软件| 国产欧美日韩精品丝袜高跟鞋| 成人动漫综合网| 国产 浪潮av性色四虎| 大胆欧美熟妇xxbbwwbw高潮了| 欧洲中文字幕一区二区| 图片区小说区av区| 国产精品一二二区视在线 | 色爱综合激情五月激情| 九九热免费在线观看视频| 国产成人无码区免费内射一片色欲 | 无码国内精品久久人妻蜜桃| 日韩av综合免费在线| 国产精品久久久久7777| 日韩高清不卡免费一区二区| 国产稚嫩高中生呻吟激情在线视频| 欧美性猛交xxxx富婆| 蜜芽久久人人超碰爱香蕉| 国产成人精品无码播放| 久久免费观看归女高潮特黄| 无码h片在线观看网站| 2021av在线| 黄床大片免费30分钟国产精品| 国产在线观看免费人成视频| 日日碰狠狠添天天爽五月婷| 九九热免费精品视频在线| 亚洲国产精品成人综合久| 国产成人精品亚洲午夜| 丝袜美腿视频一区二区三区| 欧美午夜理伦三级在线观看| 少妇粗大进出白浆嘿嘿视频| 99久re热视频这里只有精品6| 亚洲精品综合网中文字幕| 国产人伦精品一区二区三| 强奷白丝美女在线观看| 97国产成人无码精品久久久| 久久精品免费观看国产| 无码射肉在线播放视频| 亚洲男女羞羞无遮挡久久丫| 二区三区亚洲精品国产| 亚洲精品一二三在线观看|