vs2003中宏的应用:快速找页面、多行查找

1、快速找页面:
Imports EnvDTE
Imports System.Diagnostics
Imports System.Windows.Forms
Imports System.Threading

Public Module QuickFindPage
    Dim ClipString As String
    Sub QuickFindPage()
        '// take whatever is on the clipboard and save it to an xml file
        '// intended for cut & paste from QueryAnalyzer
        Dim ClipBoardThread As System.Threading.Thread = New System.Threading.Thread(AddressOf getClipString_core)
        With ClipBoardThread
            .ApartmentState = ApartmentState.STA
            .IsBackground = True
            .Start()
            '-- Wait for copy to happen
            .Join()
        End With
        ClipBoardThread = Nothing
        ClipString = Replace(ClipString, "/", "\")
        If ClipString <> "" Then
            If System.IO.File.Exists(ClipString) Then
                DTE.ItemOperations.OpenFile(ClipString)
            Else
                Dim posControl = InStr(ClipString, ".ascx")
                Dim posControl2 = InStr(ClipString, ".aspx")
                If (posControl <> 0) Then
                    Dim ClipString1 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\CO\Control\" & ClipString
                    Dim ClipString2 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\PO\Control\" & ClipString
                    Dim ClipString3 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\IV\Control\" & ClipString
                    Dim ClipString4 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\IN\Control\" & ClipString
                    Dim ClipString5 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\SH\Control\" & ClipString
                    If System.IO.File.Exists(ClipString1) Then
                        DTE.ItemOperations.OpenFile(ClipString1)
                    ElseIf System.IO.File.Exists(ClipString2) Then
                        DTE.ItemOperations.OpenFile(ClipString2)
                    ElseIf System.IO.File.Exists(ClipString3) Then
                        DTE.ItemOperations.OpenFile(ClipString3)
                    ElseIf System.IO.File.Exists(ClipString4) Then
                        DTE.ItemOperations.OpenFile(ClipString4)
                    ElseIf System.IO.File.Exists(ClipString5) Then
                        DTE.ItemOperations.OpenFile(ClipString5)
                    Else
                        MessageBox.Show("Can not find the file !")
                    End If
                ElseIf (posControl2 <> 0) Then
                    Dim ClipString1 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\CO\Page\" & ClipString
                    Dim ClipString2 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\PO\Page\" & ClipString
                    Dim ClipString3 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\IV\Page\" & ClipString
                    Dim ClipString4 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\IN\Page\" & ClipString
                    Dim ClipString5 = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\SH\Page\" & ClipString
                    If System.IO.File.Exists(ClipString1) Then
                        DTE.ItemOperations.OpenFile(ClipString1)
                    ElseIf System.IO.File.Exists(ClipString2) Then
                        DTE.ItemOperations.OpenFile(ClipString2)
                    ElseIf System.IO.File.Exists(ClipString3) Then
                        DTE.ItemOperations.OpenFile(ClipString3)
                    ElseIf System.IO.File.Exists(ClipString4) Then
                        DTE.ItemOperations.OpenFile(ClipString4)
                    ElseIf System.IO.File.Exists(ClipString5) Then
                        DTE.ItemOperations.OpenFile(ClipString5)
                    Else
                        MessageBox.Show("Can not find the file !")
                    End If
                Else
                    '虚拟目录名()
                    Dim VirtualName = "Rhombus2_YEA"
                    Dim pos = InStr(ClipString, "\" & VirtualName & "\")
                    If (pos <> 0) Then
                        ClipString = Right(ClipString, Len(ClipString) - pos - Len("\" & VirtualName & "\") + 1)
                    End If
                    pos = InStr(ClipString, "?")
                    If (pos <> 0) Then
                        ClipString = Left(ClipString, pos - 1)
                    End If
                    '组合成正确的物理路径
                    ClipString = "D:\Rhombus2\2-Software Development\4-Software Implementation\2-Source Files\Source DEV\RhombusSolution\Rhombus2\" & ClipString
                    If System.IO.File.Exists(ClipString) Then
                        DTE.ItemOperations.OpenFile(ClipString)
                    Else
                        MessageBox.Show("Can not find the file !")
                    End If
                End If
            End If
        End If
    End Sub
    Sub getClipString_core()
        ClipString = Clipboard.GetDataObject().GetData(System.Windows.Forms.DataFormats.StringFormat)
    End Sub
End Module


2、多行查找:

Imports EnvDTE
Imports System.Diagnostics
Public Module MultilineSearch
    Sub MultilineSearchReplace()
        Dim sf As New MultilineSearchForm
        sf.ShowDialog()
        If sf.result 
<> FindReplaceKind.none Then
            
' temporarily disable Tools - Options -
            ' Environment - Documents - Initialize Find text from editor
            Dim oldFindInit As Boolean
            Try
                Dim props As EnvDTE.Properties
                props 
= DTE.Properties("Environment""Documents")
                Dim prop As EnvDTE.Property 
= props.Item("FindReplaceInitializeFromEditor")
                oldFindInit 
= prop.Value
                prop.Value 
= False
            Catch ex As System.Exception
            End Try
            DTE.Find.PatternSyntax 
= vsFindPatternSyntax.vsFindPatternSyntaxRegExpr
            DTE.Find.FindWhat 
= sf.findText
            DTE.Find.ReplaceWith 
= sf.replaceText
            Select Case sf.result
                Case FindReplaceKind.find
                    DTE.ExecuteCommand(
"Edit.Find")
                Case FindReplaceKind.findInFiles
                    DTE.ExecuteCommand(
"Edit.FindinFiles")
                Case FindReplaceKind.replace
                    DTE.ExecuteCommand(
"Edit.Replace")
                Case FindReplaceKind.replaceInFiles
                    DTE.ExecuteCommand(
"Edit.ReplaceinFiles")
                Case Else
            End Select
            
' restore Tools - Options -
            ' Environment - Documents - Initialize Find text from editor
            Try
                Dim props As EnvDTE.Properties
                props 
= DTE.Properties("Environment""Documents")
                Dim prop As EnvDTE.Property 
= props.Item("FindReplaceInitializeFromEditor")
                prop.Value 
= oldFindInit
            Catch ex As System.Exception
            End Try
        End If
    End Sub
End Module
'''<summary>Types of find/replace operations.</summary>
Public Enum FindReplaceKind
    
'''<summary>Find</summary>
    find
    
'''<summary>Find In Files</summary>
    findInFiles
    
'''<summary>Replace</summary>
    replace
    
'''<summary>Replace in Files</summary>
    replaceInFiles
    
'''<summary>None. Cancel was pressed.</summary>
    none
End Enum
Public Class MultilineSearchForm
    Inherits System.Windows.Forms.Form
#Region 
" Windows Form Designer generated code "
    Public Sub New()
        MyBase.New()
        
'This call is required by the Windows Form Designer.
        InitializeComponent()
        
'Add any initialization after the InitializeComponent() call
    End Sub
    
'Form overrides dispose to clean up the component list.
    Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
        If disposing Then
            If Not (components Is Nothing) Then
                components.Dispose()
            End If
        End If
        MyBase.Dispose(disposing)
    End Sub
    
'Required by the Windows Form Designer
    Private components As System.ComponentModel.IContainer
    
'NOTE: The following procedure is required by the Windows Form Designer
    'It can be modified using the Windows Form Designer.  
    'Do not modify it using the code editor.
    Friend WithEvents FindBox As System.Windows.Forms.TextBox
    Friend WithEvents Label1 As System.Windows.Forms.Label
    Friend WithEvents Label2 As System.Windows.Forms.Label
    Friend WithEvents ReplaceBox As System.Windows.Forms.TextBox
    Friend WithEvents FindBtn As System.Windows.Forms.Button
    Friend WithEvents FindInFilesBtn As System.Windows.Forms.Button
    Friend WithEvents ReplaceBtn As System.Windows.Forms.Button
    Friend WithEvents ReplaceInFilesBtn As System.Windows.Forms.Button
    Friend WithEvents CancelBtn As System.Windows.Forms.Button
    
<System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()
        Me.FindBox 
= New System.Windows.Forms.TextBox
        Me.Label1 
= New System.Windows.Forms.Label
        Me.Label2 
= New System.Windows.Forms.Label
        Me.ReplaceBox 
= New System.Windows.Forms.TextBox
        Me.FindBtn 
= New System.Windows.Forms.Button
        Me.FindInFilesBtn 
= New System.Windows.Forms.Button
        Me.ReplaceBtn 
= New System.Windows.Forms.Button
        Me.ReplaceInFilesBtn 
= New System.Windows.Forms.Button
        Me.CancelBtn 
= New System.Windows.Forms.Button
        Me.SuspendLayout()
        
'
        'FindBox
        '
        Me.FindBox.Location = New System.Drawing.Point(1624)
        Me.FindBox.Multiline 
= True
        Me.FindBox.Name 
= "FindBox"
        Me.FindBox.ScrollBars 
= System.Windows.Forms.ScrollBars.Both
        Me.FindBox.Size 
= New System.Drawing.Size(40080)
        Me.FindBox.TabIndex 
= 0
        Me.FindBox.Text 
= ""
        
'
        'Label1
        '
        Me.Label1.Location = New System.Drawing.Point(168)
        Me.Label1.Name 
= "Label1"
        Me.Label1.Size 
= New System.Drawing.Size(16016)
        Me.Label1.TabIndex 
= 2
        Me.Label1.Text 
= "Find what:"
        
'
        'Label2
        '
        Me.Label2.Location = New System.Drawing.Point(16112)
        Me.Label2.Name 
= "Label2"
        Me.Label2.Size 
= New System.Drawing.Size(16016)
        Me.Label2.TabIndex 
= 4
        Me.Label2.Text 
= "Replace with:"
        
'
        'ReplaceBox
        '
        Me.ReplaceBox.Location = New System.Drawing.Point(16128)
        Me.ReplaceBox.Multiline 
= True
        Me.ReplaceBox.Name 
= "ReplaceBox"
        Me.ReplaceBox.ScrollBars 
= System.Windows.Forms.ScrollBars.Both
        Me.ReplaceBox.Size 
= New System.Drawing.Size(40080)
        Me.ReplaceBox.TabIndex 
= 3
        Me.ReplaceBox.Text 
= ""
        
'
        'FindBtn
        '
        Me.FindBtn.Location = New System.Drawing.Point(16232)
        Me.FindBtn.Name 
= "FindBtn"
        Me.FindBtn.Size 
= New System.Drawing.Size(8024)
        Me.FindBtn.TabIndex 
= 5
        Me.FindBtn.Text 
= "Find>>"
        
'
        'FindInFilesBtn
        '
        Me.FindInFilesBtn.Location = New System.Drawing.Point(104232)
        Me.FindInFilesBtn.Name 
= "FindInFilesBtn"
        Me.FindInFilesBtn.Size 
= New System.Drawing.Size(9624)
        Me.FindInFilesBtn.TabIndex 
= 6
        Me.FindInFilesBtn.Text 
= "Find in Files>>"
        
'
        'ReplaceBtn
        '
        Me.ReplaceBtn.Location = New System.Drawing.Point(216232)
        Me.ReplaceBtn.Name 
= "ReplaceBtn"
        Me.ReplaceBtn.Size 
= New System.Drawing.Size(8024)
        Me.ReplaceBtn.TabIndex 
= 7
        Me.ReplaceBtn.Text 
= "Replace>>"
        
'
        'ReplaceInFilesBtn
        '
        Me.ReplaceInFilesBtn.Location = New System.Drawing.Point(304232)
        Me.ReplaceInFilesBtn.Name 
= "ReplaceInFilesBtn"
        Me.ReplaceInFilesBtn.Size 
= New System.Drawing.Size(11224)
        Me.ReplaceInFilesBtn.TabIndex 
= 8
        Me.ReplaceInFilesBtn.Text 
= "Replace in Files>>"
        
'
        'CancelBtn
        '
        Me.CancelBtn.DialogResult = System.Windows.Forms.DialogResult.Cancel
        Me.CancelBtn.Location 
= New System.Drawing.Point(168272)
        Me.CancelBtn.Name 
= "CancelBtn"
        Me.CancelBtn.Size 
= New System.Drawing.Size(8024)
        Me.CancelBtn.TabIndex 
= 9
        Me.CancelBtn.Text 
= "Cancel"
        
'
        'MultilineSearchForm
        '
        Me.AutoScaleBaseSize = New System.Drawing.Size(513)
        Me.CancelButton 
= Me.CancelBtn
        Me.ClientSize 
= New System.Drawing.Size(432310)
        Me.Controls.Add(Me.CancelBtn)
        Me.Controls.Add(Me.ReplaceInFilesBtn)
        Me.Controls.Add(Me.ReplaceBtn)
        Me.Controls.Add(Me.FindInFilesBtn)
        Me.Controls.Add(Me.FindBtn)
        Me.Controls.Add(Me.Label2)
        Me.Controls.Add(Me.ReplaceBox)
        Me.Controls.Add(Me.Label1)
        Me.Controls.Add(Me.FindBox)
        Me.FormBorderStyle 
= System.Windows.Forms.FormBorderStyle.SizableToolWindow
        Me.Name 
= "MultilineSearchForm"
        Me.Text 
= "Multiline Search and Replace"
        Me.ResumeLayout(False)
    End Sub
#End Region
#Region 
"Properties"
    Private m_result As FindReplaceKind 
= FindReplaceKind.none
    
'''<summary>Gets result button from this dialog.</summary>
    '''<value>The value specifying which button was pressed.</value>
    Public ReadOnly Property result() As FindReplaceKind
        Get
            Return m_result
        End Get
    End Property
    Private m_findText As String
    
'''<summary>Gets escaped multiline text to be searched.</summary>
    '''<value></value>
    Public ReadOnly Property findText() As String
        Get
            Return m_findText
        End Get
    End Property
    Private m_replaceText As String
    
'''<summary>Gets escaped multiline replace text.</summary>
    '''<value></value>
    Public ReadOnly Property replaceText() As String
        Get
            Return m_replaceText
        End Get
    End Property
#End Region
    
'''<summary>Transforms the text to regular expression syntax.</summary>
    '''<param name="original">Original text.</param>
    '''<returns>Text with escaped regex characters.</returns>
    Private Function escapeRegEx(ByVal original As String) As String
        Dim specialChars() As Char 
= "\.*+^___FCKpd___0gt;<[]|{}:@#()~".ToCharArray
        Dim c As Char
        For Each c In specialChars
            original 
= original.Replace(c.ToString, "\" & c.ToString)
        Next
        original 
= original.Replace(vbCrLf, "\n")
        Return original
    End Function
    Private Sub MultilineSearchForm_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.Load
        Try
            Me.Activate()
        Catch ex As System.Exception
        End Try
    End Sub
    Private Sub CancelBtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles CancelBtn.Click
        Try
            m_result 
= FindReplaceKind.none
            Me.Close()
        Catch ex As System.Exception
        End Try
    End Sub
    Private Sub FindBtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles FindBtn.Click
        Try
            m_findText 
= escapeRegEx(Me.FindBox.Text)
            m_replaceText 
= escapeRegEx(Me.ReplaceBox.Text)
            m_result 
= FindReplaceKind.find
            Me.Close()
        Catch ex As System.Exception
        End Try
    End Sub
    Private Sub FindInFilesBtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles FindInFilesBtn.Click
        Try
            m_findText 
= escapeRegEx(Me.FindBox.Text)
            m_replaceText 
= escapeRegEx(Me.ReplaceBox.Text)
            m_result 
= FindReplaceKind.findInFiles
            Me.Close()
        Catch ex As System.Exception
        End Try
    End Sub
    Private Sub ReplaceBtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ReplaceBtn.Click
        Try
            m_findText 
= escapeRegEx(Me.FindBox.Text)
            m_replaceText 
= escapeRegEx(Me.ReplaceBox.Text)
            m_result 
= FindReplaceKind.replace
            Me.Close()
        Catch ex As System.Exception
        End Try
    End Sub
    Private Sub ReplaceInFilesBtn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ReplaceInFilesBtn.Click
        Try
            m_findText 
= escapeRegEx(Me.FindBox.Text)
            m_replaceText 
= escapeRegEx(Me.ReplaceBox.Text)
            m_result 
= FindReplaceKind.replaceInFiles
            Me.Close()
        Catch ex As System.Exception
        End Try
    End Sub
End Class 
原文地址:https://www.cnblogs.com/fengwenit/p/803147.html