• 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 
  • 相关阅读:
    查看jvm的cg情况
    什么是json
    httpclient工具类
    mysql 优化思路(1)
    mysql存取日期出问题
    springboot和tomcat jar包冲突
    递归
    如何去理解return?
    js BOM判断当前窗口是否最顶层。
    个人笔记,关于ajax 如果没有请求成功不允许再次请求的方法。
  • 原文地址:https://www.cnblogs.com/fengwenit/p/803147.html
Copyright © 2020-2023  润新知