當前位置: 首頁>>代碼示例>>Python>>正文


Python CodingStateMachine.get_current_charlen方法代碼示例

本文整理匯總了Python中codingstatemachine.CodingStateMachine.get_current_charlen方法的典型用法代碼示例。如果您正苦於以下問題:Python CodingStateMachine.get_current_charlen方法的具體用法?Python CodingStateMachine.get_current_charlen怎麽用?Python CodingStateMachine.get_current_charlen使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在codingstatemachine.CodingStateMachine的用法示例。


在下文中一共展示了CodingStateMachine.get_current_charlen方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: SJISProber

# 需要導入模塊: from codingstatemachine import CodingStateMachine [as 別名]
# 或者: from codingstatemachine.CodingStateMachine import get_current_charlen [as 別名]
class SJISProber(MultiByteCharSetProber):
	def __init__(self):
		MultiByteCharSetProber.__init__(self)
		self._mCodingSM = CodingStateMachine(SJISSMModel)
		self._mDistributionAnalyzer = SJISDistributionAnalysis()
		self._mContextAnalyzer = SJISContextAnalysis()
		self.reset()

	def reset(self):
		MultiByteCharSetProber.reset(self)
		self._mContextAnalyzer.reset()

	def get_charset_name(self):
		return "SHIFT_JIS"

	def feed(self, aBuf):
		aLen = len(aBuf)
		for i in range(0, aLen):
			codingState = self._mCodingSM.next_state(aBuf[i])
			if codingState == eError:
				if constants._debug:
					sys.stderr.write(self.get_charset_name() + ' prober hit error at byte ' + str(i) + '\n')
				self._mState = constants.eNotMe
				break
			elif codingState == eItsMe:
				self._mState = constants.eFoundIt
				break
			elif codingState == eStart:
				charLen = self._mCodingSM.get_current_charlen()
				if i == 0:
					self._mLastChar[1] = aBuf[0]
					self._mContextAnalyzer.feed(self._mLastChar[2 - charLen :], charLen)
					self._mDistributionAnalyzer.feed(self._mLastChar, charLen)
				else:
					self._mContextAnalyzer.feed(aBuf[i + 1 - charLen : i + 3 - charLen], charLen)
					self._mDistributionAnalyzer.feed(aBuf[i - 1 : i + 1], charLen)

		self._mLastChar[0] = aBuf[aLen - 1]

		if self.get_state() == constants.eDetecting:
			if self._mContextAnalyzer.got_enough_data() and \
				   (self.get_confidence() > constants.SHORTCUT_THRESHOLD):
				self._mState = constants.eFoundIt

		return self.get_state()

	def get_confidence(self):
		contxtCf = self._mContextAnalyzer.get_confidence()
		distribCf = self._mDistributionAnalyzer.get_confidence()
		return max(contxtCf, distribCf)
開發者ID:3cky,項目名稱:3,代碼行數:52,代碼來源:sjisprober.py

示例2: UTF8Prober

# 需要導入模塊: from codingstatemachine import CodingStateMachine [as 別名]
# 或者: from codingstatemachine.CodingStateMachine import get_current_charlen [as 別名]
class UTF8Prober(CharSetProber):
    def __init__(self):
        CharSetProber.__init__(self)
        self._mCodingSM = CodingStateMachine(UTF8SMModel)
        self.reset()

    def reset(self):
        CharSetProber.reset(self)
        self._mCodingSM.reset()
        self._mNumOfMBChar = 0

    def get_charset_name(self):
        return "utf-8"

    def feed(self, aBuf):
        for c in aBuf:
            codingState = self._mCodingSM.next_state(c)
            if codingState == eError:
                self._mState = constants.eNotMe
                break
            elif codingState == eItsMe:
                self._mState = constants.eFoundIt
                break
            elif codingState == eStart:
                if self._mCodingSM.get_current_charlen() >= 2:
                    self._mNumOfMBChar += 1

        if self.get_state() == constants.eDetecting:
            if self.get_confidence() > constants.SHORTCUT_THRESHOLD:
                self._mState = constants.eFoundIt

        return self.get_state()

    def get_confidence(self):
        unlike = 0.99
        if self._mNumOfMBChar < 6:
            for i in range(0, self._mNumOfMBChar):
                unlike = unlike * ONE_CHAR_PROB
            return 1.0 - unlike
        else:
            return unlike
開發者ID:christofoo,項目名稱:hard-way,代碼行數:43,代碼來源:ex41.py


注:本文中的codingstatemachine.CodingStateMachine.get_current_charlen方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。