主頁(yè) > 知識(shí)庫(kù) > PyQt5實(shí)現(xiàn)QLineEdit正則表達(dá)式輸入驗(yàn)證器

PyQt5實(shí)現(xiàn)QLineEdit正則表達(dá)式輸入驗(yàn)證器

熱門標(biāo)簽:企業(yè)做大做強(qiáng) Win7旗艦版 百度AI接口 客戶服務(wù) 硅谷的囚徒呼叫中心 語(yǔ)音系統(tǒng) 呼叫中心市場(chǎng)需求 電話運(yùn)營(yíng)中心

本文主要介紹了QLineEdit正則表達(dá)式輸入驗(yàn)證器,分享給大家,具體如下:

from PyQt5 import QtWidgets, QtCore, QtGui, Qt
import re

############## QLineEdit正則表達(dá)式輸入驗(yàn)證器
class LineEditRegExpValidator(QtGui.QValidator):

  '''
  # 默認(rèn)為科學(xué)計(jì)數(shù)法輸入驗(yàn)證器

  用法
  SciNotValidator = LineEditRegExpValidator() # 創(chuàng)建一個(gè)QLineEdit正則表達(dá)式輸入驗(yàn)證器的類,默認(rèn)為科學(xué)計(jì)數(shù)法輸入驗(yàn)證器

  self.LineEdit1.setValidator(SciNotValidator) # 設(shè)置驗(yàn)證器(啟用)
  self.LineEdit1.installEventFilter(SciNotValidator) # QLineEdit清空內(nèi)容且游標(biāo)失焦時(shí),自動(dòng)填充上一次的字符串內(nèi)容

  self.LineEdit2.setValidator(SciNotValidator)
  self.LineEdit2.installEventFilter(SciNotValidator)

  self.LineEdit3.setValidator(SciNotValidator)
  self.LineEdit3.installEventFilter(SciNotValidator)

  Validator.validate() is abstract and must be overriddenValidator.validate() is abstract and must be overridden
  '''

  def __init__(
    self, 

    # 編輯狀態(tài)框輸入結(jié)束允許的字符串
    fullPatterns=[
      r"[+|-]?[0-9]+\.?[0-9]*(?:[Ee][+|-]?[0-9]+)?", 
      r'[+|-]{0,1}nan', r'[+|-]{0,1}inf'
      ], 
    
    # 編輯狀態(tài)框輸入尚未結(jié)束允許的字符串
    partialPatterns=[
      r'[+|-]?[0-9]+\.?[0-9]*(?:[Ee][+|-]?)?', 
      r'-', 
      r'\+', 
      r'[+|-]{0,1}nan', 
      r'[+|-]{0,1}na', 
      r'[+|-]{0,1}n', 
      r'[+|-]{0,1}inf', 
      r'[+|-]{0,1}in', 
      r'[+|-]{0,1}i'
      ],
    
    fixupString='1.0'
    ):

    super(LineEditRegExpValidator, self).__init__()
    self.fullPatterns = fullPatterns
    self.partialPatterns = partialPatterns
    self.fixupString = fixupString
  

  # 實(shí)時(shí)監(jiān)聽(tīng)文本框的改變
  # 可能是鍵盤單個(gè)字符'n'輸入, 也有可能是粘貼多個(gè)字符'nan'輸入
  def validate(self, string, pos) -> QtGui.QValidator.State: # string為編輯狀態(tài)框中可見(jiàn)的字符串+輸入字符/字符串

    # 編輯過(guò)程結(jié)束,若返回True,將編輯狀態(tài)框中的字符串填入LineEdit,若返回Flase則自動(dòng)調(diào)用self.fixup方法,將fixup方法返回的字符串填入LineEdit
    if self.acceptable_check(string):
      #print(f'QtGui.QValidator.Acceptable:{QtGui.QValidator.Acceptable}')
      return QtGui.QValidator.Acceptable, string, pos # QtGui.QValidator.Acceptable = 2; 
    

    # 編輯過(guò)程中允許出現(xiàn)的字符串
    if self.intermediate_check(string):
      #print(f'QtGui.QValidator.Intermediate:{QtGui.QValidator.Intermediate}')
      return QtGui.QValidator.Intermediate, string, pos # QtGui.QValidator.State = 1;
    # 編輯過(guò)程中不允許出現(xiàn)的字符串(本次輸入的單個(gè)字符或字符串無(wú)效)
    else:
      #print(f'QtGui.QValidator.Invalid:{QtGui.QValidator.Invalid}')
      return QtGui.QValidator.Invalid, string, pos


  # 編輯狀態(tài)框驗(yàn)證通過(guò), 編輯狀態(tài)框單個(gè)字輸入符成功
  def acceptable_check(self, string) -> bool:
    True_ = 0
    for fullPattern in self.fullPatterns:
      if re.fullmatch(fullPattern, string):
        True_ += 1
      else:
        continue
    if True_ != 0:
      return True
    else:
      return False

  # 輸入還未結(jié)束允許的字符串
  def intermediate_check(self, string): #-> bool;  string為編輯狀態(tài)框中可見(jiàn)的字符串
    """
    Checks if string makes a valid partial float, keeping in mind locale dependent decimal separators.
    """
    if string == '':
      return True
    for partialPattern in self.partialPatterns:
      if re.fullmatch(partialPattern, string):
        return True
      else:
        pass

  # 
  def eventFilter(self, lineEdit, event): # -> bool
    # FocusIn event
    # 每當(dāng)fous in時(shí),更新LineEditRegExpValidator的fixupString
    # 輸入驗(yàn)證器
    '''
    SciNotValidator = LineEditRegExpValidator()

    self.LineEdit1.setValidator(SciNotValidator)
    self.LineEdit1.installEventFilter(SciNotValidator)
    '''

    if event.type() == QtCore.QEvent.FocusIn:
      # do custom stuff
      # print('focus in')

      # self.lineEdit_zhuansu.installEventFilter(SciNotValidator), 在本類中,widget是self.lineEdit,執(zhí)行函數(shù)self.lineEdit.text(), 其它類不一定有text()方法

      #lineEdit.selectAll()
      QtCore.QTimer.singleShot(0, lineEdit.selectAll) # 0ms
      self.fixupString = lineEdit.text()

      #print(self.fixupString)
      # return False so that the lineEdit will also handle the event
      # otherwise it won't focus out
      return False
    else:
      # we don't care about other events
      return False

  # 重寫QValidator的fixup(str)方法。可以在切換焦點(diǎn)后,直接修改不合規(guī)則的字符串。參數(shù)str是經(jīng)過(guò)validate()方法驗(yàn)證后的字符串;
  def fixup(self, string) -> str:
    """
    Fixes up input text to create a valid float. Puts an empty string on failure.
    """
    print(string)

    True_ = 0
    for fullPattern in self.fullPatterns:
      if re.fullmatch(fullPattern, string):
        True_ += 1
      else:
        continue
    if True_ != 0:
      return string
    else:
      return self.fixupString


# listWidget、tableWidget輸入數(shù)據(jù)檢查
class LineEditDelegate_Regx(QtWidgets.QStyledItemDelegate):
 # 科學(xué)計(jì)數(shù)法正則表達(dá)式
  regx = r"-?\ *[0-9]+\.?[0-9]*(?:[Ee]\ *-?\ *[0-9]+)?" #
  """
  -?    optionally matches a negative sign (zero or one negative signs)
  \ *    matches any number of spaces (to allow for formatting variations like - 2.3 or -2.3)
  [0-9]+  matches one or more digits
  \.?    optionally matches a period (zero or one periods)
  [0-9]*  matches any number of digits, including zero
  (?: ... ) groups an expression, but without forming a "capturing group" (look it up)
  [Ee]   matches either "e" or "E"
  \ *    matches any number of spaces (to allow for formats like 2.3E5 or 2.3E 5)
  -?    optionally matches a negative sign
  \ *    matches any number of spaces
  [0-9]+  matches one or more digits
  ?     makes the entire non-capturing group optional (to allow for the presence or absence of the exponent - 3000 or 3E3

  https://stackoverflow.com/questions/18152597/extract-scientific-number-from-string
  """

  """
  用法:
  def __init__(self, parent=None):
    super(NewClassName, self).__init__(parent)
    self.setupUi(self)

    delegate = LineEditDelegate_Regx(regx=None)
    self.listWidget_ShuZhiLieBiao.setItemDelegate(delegate)
    self.tableWidget.setItemDelegate(delegate)
  """
  def __init__(self, regx=None, parent=None):
    super(LineEditDelegate_Regx, self).__init__(parent)
    if regx == None:
      pass
    else:
      self.regx = regx

  # 方法重寫
  def createEditor(self, parent, option, index): # self, parent, option, index四個(gè)參數(shù)均不能少
    editor_qlineedit = QtWidgets.QLineEdit(parent)
    #SciNotValidator = QtGui.QRegExpValidator(QtCore.QRegExp(self.regx))
    SciNotValidator = LineEditRegExpValidator()
    editor_qlineedit.setValidator(SciNotValidator)
    return editor_qlineedit # LineEditDelegate_Regx(regx=None, parent=None), QStyledItemDelegate(parent: QObject = None)

"""
# LineEdit輸入數(shù)據(jù)檢查
def LineEditInputChecking(lineEdit, regx=None):
  '''
  用法:
  LineEditInputChecking(lineEdit=self.lineEdit_zhuansu)
  '''
  if regx == None:
    regx = r"-?\ *[0-9]+\.?[0-9]*(?:[Ee]\ *-?\ *[0-9]+)?"
  reg_ex = QtCore.QRegExp(regx)
  input_validator = QtGui.QRegExpValidator(reg_ex, lineEdit)
  lineEdit.setValidator(input_validator)
"""

參考:

https://stackoverflow.com/questions/39202697/qt-qlineedit-input-validation

https://stackoverflow.com/questions/15829782/how-to-restrict-user-input-in-qlineedit-in-pyqt

到此這篇關(guān)于PyQt5實(shí)現(xiàn)QLineEdit正則表達(dá)式輸入驗(yàn)證器的文章就介紹到這了,更多相關(guān)PyQt5 QLineEdit驗(yàn)證器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • PyQt5 QLineEdit輸入的子網(wǎng)字符串校驗(yàn)QRegExp實(shí)現(xiàn)
  • PyQt5 文本輸入框自動(dòng)補(bǔ)全QLineEdit的實(shí)現(xiàn)示例
  • python GUI庫(kù)圖形界面開(kāi)發(fā)之PyQt5單行文本框控件QLineEdit詳細(xì)使用方法與實(shí)例
  • PyQt5實(shí)現(xiàn)QLineEdit添加clicked信號(hào)的方法
  • 在pyqt5中QLineEdit里面的內(nèi)容回車發(fā)送的實(shí)例

標(biāo)簽:長(zhǎng)沙 喀什 安康 海南 山西 崇左 濟(jì)南 山西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PyQt5實(shí)現(xiàn)QLineEdit正則表達(dá)式輸入驗(yàn)證器》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266