使用 Python3 實(shí)現(xiàn)全角半角轉(zhuǎn)換

前言

本文主要給大家介紹了關(guān)于python3中全角和半角字符轉(zhuǎn)換的相關(guān)內(nèi)容,分享出來(lái)供大家參考學(xué)習(xí),下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧。

一、背景介紹

解決什么問(wèn)題:快速方便的對(duì)文本進(jìn)行全角半角自動(dòng)轉(zhuǎn)換

適用什么場(chǎng)景:學(xué)生答題數(shù)據(jù)中全角字符替換為半角字符

二、全角半角原理

全角即:Double Byte Character,簡(jiǎn)稱(chēng)DBC

半角即:Single Byte Character,簡(jiǎn)稱(chēng)SBC

在 windows 中,中文和全角字符都占兩個(gè)字節(jié),并且使用了 ascii chart 2 (codes 128–255);
全角字符的第一個(gè)字節(jié)總是被置為 163,而第二個(gè)字節(jié)則是相同半角字符碼加上128(不包括空格,全角空格和半角空格也要考慮進(jìn)去);

對(duì)于中文來(lái)說(shuō),它的第一個(gè)字節(jié)被置為大于163,如'阿'為:176 162,檢測(cè)到中文時(shí)不進(jìn)行轉(zhuǎn)換。

例如:半角 a 為 65,則全角 a 是 163(第一個(gè)字節(jié))、193(第二個(gè)字節(jié),128+65)。

三、使用 Python3 實(shí)現(xiàn)全角半角轉(zhuǎn)換

# -*- coding:utf-8 -*-
# i@mail.chenpeng.info

”'
全角即:Double Byte Character,簡(jiǎn)稱(chēng):DBC
半角即:Single Byte Character,簡(jiǎn)稱(chēng):SBC
”'

def DBC2SBC(ustring):
 ”' 全角轉(zhuǎn)半角 ”'
 rstring = “”
 for uchar in ustring:
  inside_code = ord(uchar)
  if inside_code == 0x3000:
  inside_code = 0x0020
  else:
  inside_code -= 0xfee0
  if not (0x0021 <= inside_code and inside_code <= 0x7e):
   rstring += uchar
   continue
  rstring += chr(inside_code)
 return rstring

def SBC2DBC(ustring):
 ”' 半角轉(zhuǎn)全角 ”'
 rstring = “”
 for uchar in ustring:
  inside_code = ord(uchar)
  if inside_code == 0x0020:
  inside_code = 0x3000
  else:
  if not (0x0021 <= inside_code and inside_code <= 0x7e):
   rstring += uchar
   continue
  inside_code += 0xfee0
  rstring += chr(inside_code)
 return rstring

s = ”'
array(‘0' => ‘0', ‘1' => ‘1', ‘2' => ‘2', ‘3' => ‘3', ‘4' => ‘4',
  ‘5' => ‘5', ‘6' => ‘6', ‘7' => ‘7', ‘8' => ‘8', ‘9' => ‘9',
  ‘A' => ‘A', ‘B' => ‘B', ‘C' => ‘C', ‘D' => ‘D', ‘E' => ‘E',
  ‘F' => ‘F', ‘G' => ‘G', ‘H' => ‘H', ‘I' => ‘I', ‘J' => ‘J',
  ‘K' => ‘K', ‘L' => ‘L', ‘M' => ‘M', ‘N' => ‘N', ‘O' => ‘O',
  ‘P' => ‘P', ‘Q' => ‘Q', ‘R' => ‘R', ‘S' => ‘S', ‘T' => ‘T',
  ‘U' => ‘U', ‘V' => ‘V', ‘W' => ‘W', ‘X' => ‘X', ‘Y' => ‘Y',
  ‘Z' => ‘Z', ‘a' => ‘a(chǎn)', ‘b' => ‘b', ‘c' => ‘c', ‘d' => ‘d',
  ‘e' => ‘e', ‘f' => ‘f', ‘g' => ‘g', ‘h' => ‘h', ‘i' => ‘i',
  ‘j' => ‘j', ‘k' => ‘k', ‘l' => ‘l', ‘m' => ‘m', ‘n' => ‘n',
  ‘o' => ‘o', ‘p' => ‘p', ‘q' => ‘q', ‘r' => ‘r', ‘s' => ‘s',
  ‘t' => ‘t', ‘u' => ‘u', ‘v' => ‘v', ‘w' => ‘w', ‘x' => ‘x',
  ‘y' => ‘y', ‘z' => ‘z',
  ‘(' => ‘(‘, ‘)' => ‘)', ‘〔' => ‘[‘, ‘〕' => ‘]', ‘【' => ‘[‘,
  ‘】' => ‘]', ‘〖' => ‘[‘, ‘〗' => ‘]', ‘”‘ => ‘[‘, ‘”‘ => ‘]',
  ‘\” => ‘[‘, ‘\” => ‘]', ‘{' => ‘{‘, ‘}' => ‘}', ‘《' => ‘<‘,
  ‘》' => ‘>',
  ‘%' => ‘%', ‘+' => ‘+', ‘—' => ‘-‘, ‘-' => ‘-‘, ‘~' => ‘-‘,
  ‘:' => ‘:', ‘。' => ‘.', ‘、' => ‘,', ‘,' => ‘.', ‘、' => ‘.',
  ‘;' => ‘,', ‘?' => ‘?', ‘!' => ‘!', ‘…' => ‘-‘, ‘‖' => ‘|',
  ‘”‘ => ‘”‘, ‘\” => ‘`', ‘\” => ‘`', ‘|' => ‘|', ‘〃' => ‘”‘,
  ‘ ' => ‘ ‘);
  ”'

# 全角轉(zhuǎn)半角
print(DBC2SBC(s))

# 半角轉(zhuǎn)全角
print(SBC2DBC(s))

s = ”'中文測(cè)試”'

# 全角轉(zhuǎn)半角
print(DBC2SBC(s))

# 半角轉(zhuǎn)全角
print(SBC2DBC(s))

參考資料:http://thinkerou.com/2015-06/covert-dbc-sbc/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容