国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Linux|Centos|Ubuntu|系統(tǒng)進(jìn)程|Fedora|注冊表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

香港云服务器
服務(wù)器之家 - 服務(wù)器系統(tǒng) - Linux - Linux下將UTF8編碼批量轉(zhuǎn)換成GB2312編碼的方法

Linux下將UTF8編碼批量轉(zhuǎn)換成GB2312編碼的方法

2019-10-24 19:27Linux教程網(wǎng) Linux

在sqlplus中導(dǎo)入U(xiǎn)TF8編碼的sql腳本就會(huì)出現(xiàn)亂碼錯(cuò)誤,這時(shí)就需要將UTF8編碼轉(zhuǎn)換成GB2312編碼,下面為大家介紹下在Linux下如何進(jìn)行轉(zhuǎn)換

UTF8編碼GB2312編碼是有區(qū)別的,在sqlplus中導(dǎo)入U(xiǎn)TF8編碼的sql腳本就會(huì)出現(xiàn)亂碼錯(cuò)誤,這時(shí)就需要將UTF8編碼轉(zhuǎn)換成GB2312編碼,可是一個(gè)個(gè)的轉(zhuǎn)換十分麻煩,下面小編就教你如何在Linux下將UTF8編碼批量轉(zhuǎn)換成GB2312編碼。

Linux下將UTF8編碼批量轉(zhuǎn)換成GB2312編碼的方法

  背景

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

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

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

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

  3.關(guān)于最后的sed命令,那是因?yàn)楸救说南到y(tǒng)上沒有unix2dos命令,所以進(jìn)行了模擬,目的是為了方便自己在windows下查看和編輯

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

延伸 · 閱讀

精彩推薦
383
主站蜘蛛池模板: 午夜伦理影院 | 日韩在线电影 | 在线观看亚洲专区 | 国产高潮国产高潮久久久91 | 久久精品视频网站 | 一区在线观看 | 欧美亚洲国产一区二区三区 | 国产伦精品一区二区三区四区视频 | 亚洲在线 | 亚洲视频在线视频 | 日本成人中文字幕 | 超碰日韩 | 国产在线欧美 | 色爱av | 福利视频在线播放 | 中文字幕在线一区二区三区 | 夜夜摸夜夜操 | 91短视频版在线观看www免费 | 国产美女av在线 | 国产日韩成人 | 久久思久久 | 国产目拍亚洲精品99久久精品 | 99久久99久久精品 | 黄色一级电影在线观看 | 91在线免费视频 | 久久99国产精一区二区三区 | 狠狠香蕉 | 色狠狠久久av五月综合 | 操操网站| 在线国产一区二区 | 国产精品久久久久精 | 日本一级淫片免费看 | 青青草久久网 | 97精品视频| 国产成人一级片 | 特级西西人体444www高清大胆 | 91在线看片 | 国产精品国产三级国产aⅴ中文 | 国产一区二区亚洲 | 九九综合 | 欧美在线不卡视频 |