随笔-13  评论-29  文章-31  trackbacks-0

要正确运行本工具, 需事先要安装vbScript5.6 + VB开发工具.
整个文件可以通过下面的链接下载:
http://www.cnitblog.com/Files/oliver_yin/RegualTool.rar

工程文件: PrjRegualExpressTool.vbp
Type=Exe
Reference=*\G{00020430-0000-0000-C000-000000000046}#2.0#0#C:\WINNT\system32\stdole2.tlb#OLE Automation
Reference=*\G{3F4DACA7-160D-11D2-A8E9-00104B365C9F}#5.5#0#C:\WINNT\system32\vbscript.dll\3#Microsoft VBScript Regular Expressions 5.5
Form=FrmRegTool.frm
Startup="FrmRegTool"
Command32=""
Name="PrjRegualExpressTool"
HelpContextID="0"
CompatibleMode="0"
MajorVer=1
MinorVer=0
RevisionVer=0
AutoIncrementVer=0
ServerSupportFiles=0
VersionCompanyName="gcecn"
CompilationType=0
OptimizationType=0
FavorPentiumPro(tm)=0
CodeViewDebugInfo=0
NoAliasing=0
BoundsCheck=0
OverflowCheck=0
FlPointCheck=0
FDIVCheck=0
UnroundedFP=0
StartMode=0
Unattended=0
Retained=0
ThreadPerObject=0
MaxNumberOfThreads=1

[MS Transaction Server]
AutoRefresh=1

窗体文件: FrmRegTool.frm

VERSION 5.00
Begin VB.Form FrmRegTool
   BorderStyle     =   3  'Fixed Dialog
   Caption         =   "正则表达式测试工具"
   ClientHeight    =   8760
   ClientLeft      =   45
   ClientTop       =   330
   ClientWidth     =   10365
   LinkTopic       =   "Form1"
   MaxButton       =   0   'False
   MinButton       =   0   'False
   ScaleHeight     =   8760
   ScaleWidth      =   10365
   StartUpPosition =   3  'Windows Default
   Begin VB.Frame Frame5
      Caption         =   "Replace Text"
      BeginProperty Font
         Name            =   "MS Sans Serif"
         Size            =   12
         Charset         =   0
         Weight          =   400
         Underline       =   0   'False
         Italic          =   0   'False
         Strikethrough   =   0   'False
      EndProperty
      Height          =   1095
      Left            =   0
      TabIndex        =   21
      Top             =   3360
      Width           =   10335
      Begin VB.TextBox TxtReplace
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   615
         Left            =   120
         MultiLine       =   -1  'True
         ScrollBars      =   3  'Both
         TabIndex        =   24
         Top             =   360
         Width           =   8175
      End
      Begin VB.CommandButton Command6
         Caption         =   "Cle&ar"
         Height          =   495
         Left            =   8520
         TabIndex        =   23
         Top             =   360
         Width           =   735
      End
      Begin VB.CommandButton Command5
         Caption         =   "Cop&y"
         Height          =   495
         Left            =   9480
         TabIndex        =   22
         Top             =   360
         Width           =   735
      End
   End
   Begin VB.Frame Frame4
      Caption         =   "Regex Expression"
      BeginProperty Font
         Name            =   "MS Sans Serif"
         Size            =   12
         Charset         =   0
         Weight          =   400
         Underline       =   0   'False
         Italic          =   0   'False
         Strikethrough   =   0   'False
      EndProperty
      Height          =   1335
      Left            =   0
      TabIndex        =   13
      Top             =   2040
      Width           =   5535
      Begin VB.CommandButton Command4
         Caption         =   "Cop&y"
         Height          =   375
         Left            =   4800
         TabIndex        =   20
         Top             =   840
         Width           =   615
      End
      Begin VB.CommandButton Command1
         Caption         =   "Cle&ar"
         Height          =   375
         Left            =   4800
         TabIndex        =   19
         Top             =   360
         Width           =   615
      End
      Begin VB.TextBox TxtReg
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   855
         Left            =   120
         MultiLine       =   -1  'True
         ScrollBars      =   2  'Vertical
         TabIndex        =   14
         Text            =   "FrmRegTool.frx":0000
         Top             =   360
         Width           =   4575
      End
   End
   Begin VB.Frame Frame3
      Caption         =   "Text To Match"
      BeginProperty Font
         Name            =   "MS Sans Serif"
         Size            =   12
         Charset         =   0
         Weight          =   400
         Underline       =   0   'False
         Italic          =   0   'False
         Strikethrough   =   0   'False
      EndProperty
      Height          =   1935
      Left            =   0
      TabIndex        =   9
      Top             =   0
      Width           =   10335
      Begin VB.CommandButton Command2
         Caption         =   "&Paste"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   615
         Left            =   8640
         TabIndex        =   12
         Top             =   1200
         Width           =   1575
      End
      Begin VB.CommandButton Command3
         Caption         =   "&Clear"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   615
         Left            =   8640
         TabIndex        =   11
         Top             =   360
         Width           =   1575
      End
      Begin VB.TextBox TxtString
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   1455
         Left            =   120
         MultiLine       =   -1  'True
         ScrollBars      =   3  'Both
         TabIndex        =   10
         Text            =   "FrmRegTool.frx":0015
         Top             =   360
         Width           =   8295
      End
   End
   Begin VB.Frame Frame2
      Caption         =   "Results of match"
      BeginProperty Font
         Name            =   "MS Sans Serif"
         Size            =   12
         Charset         =   0
         Weight          =   400
         Underline       =   0   'False
         Italic          =   0   'False
         Strikethrough   =   0   'False
      EndProperty
      Height          =   3855
      Left            =   0
      TabIndex        =   4
      Top             =   4440
      Width           =   10335
      Begin VB.CommandButton CmdClear
         Caption         =   "Cl&ear"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   375
         Left            =   1920
         TabIndex        =   18
         Top             =   3360
         Width           =   1695
      End
      Begin VB.CommandButton CmdCopy
         Caption         =   "&To Clipboard"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   375
         Left            =   4440
         TabIndex        =   17
         Top             =   3360
         Width           =   1695
      End
      Begin VB.CommandButton CmdSubMatchs
         Caption         =   "&Sub Matches"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   615
         Left            =   8520
         TabIndex        =   15
         Top             =   2520
         Width           =   1575
      End
      Begin VB.CommandButton CmdMatchs
         Caption         =   "&Match Collection"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   615
         Left            =   8520
         TabIndex        =   8
         Top             =   1800
         Width           =   1575
      End
      Begin VB.CommandButton CmdReplace
         Caption         =   "&Replace"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   615
         Left            =   8520
         TabIndex        =   7
         Top             =   1080
         Width           =   1575
      End
      Begin VB.CommandButton CmdTest
         Caption         =   "&ISMatch?"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   615
         Left            =   8520
         TabIndex        =   6
         Top             =   360
         Width           =   1575
      End
      Begin VB.TextBox TxtOutput
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   12
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   2895
         Left            =   120
         MultiLine       =   -1  'True
         ScrollBars      =   3  'Both
         TabIndex        =   5
         Text            =   "FrmRegTool.frx":0045
         Top             =   360
         Width           =   8175
      End
      Begin VB.Label Label1
         AutoSize        =   -1  'True
         BackStyle       =   0  'Transparent
         Caption         =   "本工具后台解析器采用VBScript 5.5."
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   9.75
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         ForeColor       =   &H00FF0000&
         Height          =   240
         Left            =   7320
         TabIndex        =   16
         Top             =   3600
         Width           =   2925
         WordWrap        =   -1  'True
      End
   End
   Begin VB.Frame Frame1
      Caption         =   "Regex Options"
      BeginProperty Font
         Name            =   "MS Sans Serif"
         Size            =   12
         Charset         =   0
         Weight          =   400
         Underline       =   0   'False
         Italic          =   0   'False
         Strikethrough   =   0   'False
      EndProperty
      Height          =   1335
      Left            =   5640
      TabIndex        =   0
      Top             =   2040
      Width           =   4695
      Begin VB.CheckBox ChkMultiLine
         Caption         =   "Multi  Line"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   12
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   375
         Left            =   240
         TabIndex        =   3
         Top             =   840
         Width           =   1455
      End
      Begin VB.CheckBox ChkIgnorecase
         Caption         =   "Ignore Case"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   12
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   375
         Left            =   2400
         TabIndex        =   2
         Top             =   360
         Width           =   1695
      End
      Begin VB.CheckBox ChkGlobal
         Caption         =   "Global"
         BeginProperty Font
            Name            =   "MS Sans Serif"
            Size            =   12
            Charset         =   0
            Weight          =   400
            Underline       =   0   'False
            Italic          =   0   'False
            Strikethrough   =   0   'False
         EndProperty
         Height          =   375
         Left            =   240
         TabIndex        =   1
         Top             =   360
         Width           =   1095
      End
   End
   Begin VB.Label Label2
      Caption         =   "注意:考虑到有可能有特殊字符的匹配,  每个文本框都没有使用Trim进行处理"
      ForeColor       =   &H000000FF&
      Height          =   255
      Left            =   120
      TabIndex        =   25
      Top             =   8400
      Width           =   9855
   End
End
Attribute VB_Name = "FrmRegTool"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = True
Attribute VB_Exposed = False
Option Explicit

Private strTemp As String

Private Sub CmdClear_Click()
 TxtOutput.Text = ""
End Sub

Private Sub CmdCopy_Click()
 Dim TmpStr As String
       
    '清除剪贴板
    Clipboard.Clear
   
    TmpStr = TxtOutput.Text
    Clipboard.SetText TmpStr

End Sub

Private Sub CmdMatchs_Click()
 '给出所有的match的结果
    If Trim(TxtString) <> "" And Trim(TxtReg.Text) <> "" Then
       TxtOutput.ForeColor = vbBlack
       TxtOutput = RegExpMatchs(TxtReg.Text, TxtString.Text)
    End If
 
End Sub

Private Sub CmdReplace_Click()
 '进行替换动作
 
    If Trim(TxtString) <> "" And Trim(TxtReg.Text) <> "" And Trim(TxtReplace.Text) <> "" Then
       TxtOutput.ForeColor = vbBlack
       TxtOutput = ReplaceTest(TxtReg.Text, TxtReplace.Text, TxtString.Text)
    End If
   
End Sub

Private Sub CmdSubMatchs_Click()
 'sub matches
 TxtOutput.Text = SubMatchTest(Trim(TxtReg.Text), TxtString.Text)
 
End Sub

Private Sub CmdTest_Click()
 '检查表达式是否有效
     If Trim(TxtString) <> "" And Trim(TxtReg.Text) <> "" Then
        If RegExpTest(TxtReg.Text, TxtString.Text) Then
           TxtOutput.ForeColor = vbRed
           TxtOutput.Text = "Match success!"
          Else
           TxtOutput.Text = "Match fail!"
        End If
    End If
 
End Sub

Private Sub Command1_Click()
 TxtReg.Text = ""
End Sub

'Private reg As New RegExp

'Private Sub Command1_Click()
''测试正则表达式
' Dim ss, re, rv
'ss = "Is is the cost of of gasoline going up up?." & vbNewLine
'Set re = New RegExp
're.Pattern = "\b([a-z][A-Z]+) \1\b"
're.Global = True
're.IgnoreCase = True
're.MultiLine = True
'rv = re.Replace(ss, "$1")
'
'TxtOutput.Text = rv
'
'
'End Sub

Private Sub Command2_Click()
 '从剪贴板Paste
   TxtString.Text = Clipboard.GetText
 
End Sub

Private Sub Command3_Click()
'Clear 文本框
  TxtString.Text = ""
End Sub

 

Private Sub Command4_Click()
Dim TmpStr As String
       
    '清除剪贴板
    Clipboard.Clear
   
    TmpStr = TxtReg.Text
    Clipboard.SetText TmpStr
   
End Sub

Private Sub Command5_Click()
Dim TmpStr As String
       
    '清除剪贴板
    Clipboard.Clear
   
    TmpStr = TxtReplace.Text
    Clipboard.SetText TmpStr
   
End Sub

Private Sub Command6_Click()
 '清空replace 文本
 TxtReplace.Text = ""
End Sub

Private Sub Form_Load()


  Call Command1_Click
  Call Command3_Click
  Call Command6_Click
  Call CmdClear_Click
End Sub

Function RegExpMatchs(patrn As String, strng As String) As String

  '执行有效性测试
  Dim regEx As RegExp
  Dim Match1 As Match
  Dim Matches As MatchCollection
  Dim retStr  As String ' Create variable.
 
  On Error GoTo ErrorHandle
  Screen.MousePointer = 11
 
   Set regEx = New RegExp   ' Create a regular expression.
   regEx.Pattern = patrn   ' Set pattern.
   regEx.IgnoreCase = ChkIgnorecase.Value   ' Set case insensitivity.
   regEx.Global = ChkGlobal.Value  ' Set global applicability.
   regEx.MultiLine = ChkMultiLine.Value
 
   If regEx.Test(strng) Then
      Set Matches = regEx.Execute(strng)   ' Execute search.
     
        retStr = retStr & "FirstIndex " & vbTab & "Match Value" & vbCrLf
       
        For Each Match1 In Matches   ' Iterate Matches collection.
           retStr = retStr & Match1.FirstIndex & vbTab
           retStr = retStr & Match1.Value & vbCrLf
        Next
        RegExpMatchs = retStr
      Else
        RegExpMatchs = "Match not found"
   End If
  
ExitProcedure:
 Screen.MousePointer = 0
 Exit Function
   
ErrorHandle:                ' Error-handling routine.
 
       strTemp = "Error # " & Str(Err.Number) & " was generated by " _
             & Err.Source & Chr(11) & Err.Description
       MsgBox strTemp, vbOKOnly + vbCritical, Me.Caption, Err.HelpFile, Err.HelpContext
       RegExpMatchs = "Error!"
   Screen.MousePointer = 0
End Function
Function RegExpTest(patrn As String, strng As String) As Boolean

  '执行有效性测试
  Dim regEx As RegExp
  Dim Match1 As Match
  Dim Matches As MatchCollection
  Dim retStr  As String ' Create variable.
 
  On Error GoTo ErrorHandle
  Screen.MousePointer = 11
 
   Set regEx = New RegExp   ' Create a regular expression.
   regEx.Pattern = patrn   ' Set pattern.
   regEx.IgnoreCase = ChkIgnorecase.Value   ' Set case insensitivity.
   regEx.Global = ChkGlobal.Value  ' Set global applicability.
   regEx.MultiLine = ChkMultiLine.Value
 
   RegExpTest = regEx.Test(strng)

ExitProcedure:
 Screen.MousePointer = 0
 Exit Function
   
ErrorHandle:      ' Error-handling routine.
 
       strTemp = "Error # " & Str(Err.Number) & " was generated by " _
             & Err.Source & Chr(11) & Err.Description
       MsgBox strTemp, vbOKOnly + vbCritical, Me.Caption, Err.HelpFile, Err.HelpContext
       RegExpTest = False
   Screen.MousePointer = 0
  
End Function

Function SubMatchTest(patrn As String, inpStr As String) As String

  Dim oRe As RegExp
  Dim oMatch As Match
  Dim oMatches As MatchCollection
  Dim retStr As String
 ' Dim oSubMatches As SubMatches
  Dim i, j As Long
 
  On Error GoTo ErrorHandle
  Screen.MousePointer = 11
 
  Set oRe = New RegExp
  ' Look for an e-mail address (not a perfect RegExp)
  'oRe.Pattern = "(\w+)@(\w+)\.(\w+)"
    oRe.Pattern = patrn
   oRe.IgnoreCase = ChkIgnorecase.Value   ' Set case insensitivity.
   oRe.Global = ChkGlobal.Value  ' Set global applicability.
   oRe.MultiLine = ChkMultiLine.Value
 
 
  If oRe.Test(inpStr) Then
        ' Get the Matches collection
        Set oMatches = oRe.Execute(inpStr)
            retStr = "Matches hierarchy :" & vbNewLine
         For i = 0 To oMatches.Count - 1
            Set oMatch = oMatches(i)
            retStr = retStr & "Match " & i & vbTab & oMatches(i) & vbNewLine
            For j = 0 To oMatch.SubMatches.Count - 1
                retStr = retStr & vbTab & "subMatch " & j & vbTab & oMatch.SubMatches(j) & vbNewLine
             
            Next j
           
         Next i
         SubMatchTest = retStr
        
      
       
    Else
       SubMatchTest = "Match not found"
   End If
  
ExitProcedure:
 Screen.MousePointer = 0
 Exit Function
   
ErrorHandle:                ' Error-handling routine.
 
       strTemp = "Error # " & Str(Err.Number) & " was generated by " _
             & Err.Source & Chr(11) & Err.Description
       MsgBox strTemp, vbOKOnly + vbCritical, Me.Caption, Err.HelpFile, Err.HelpContext
      
       SubMatchTest = "Error!"
   Screen.MousePointer = 0
  
End Function

Function ReplaceTest(patrn As String, replStr As String, StrTobeReplace As String) As String
  Dim regEx As RegExp
    
   Set regEx = New RegExp            ' Create regular expression.
   regEx.Pattern = patrn   ' Set pattern.
   regEx.IgnoreCase = ChkIgnorecase.Value   ' Set case insensitivity.
   regEx.Global = ChkGlobal.Value  ' Set global applicability.
   regEx.MultiLine = ChkMultiLine.Value
  
  ReplaceTest = regEx.Replace(StrTobeReplace, replStr)   ' Make replacement.
 
End Function


 

posted on 2005-08-20 12:15 生活像一团麻 阅读(957) 评论(0)  编辑 收藏 引用 所属分类: 正则表达式
只有注册用户登录后才能发表评论。