2016.1.1 VS中宏的使用技巧点滴

时间:2023-03-08 22:58:50
2016.1.1 VS中宏的使用技巧点滴

Dim selection As TextSelection = DTE.ActiveDocument.Selection'定义 TextSelection 对象

selection.StartOfLine()'移动到当前光标所在行的起始位置

Dim keyword = selection.Text.Trim()'取得整行文本

'获取当前选择首点所在行

Dim endLine As Integer

endLine = selection.TopPoint.Line

selection.NewLine()'插入一行空白行

selection.LineUp()'将光标移回到新空白行

selection.GotoLine(startLine) '将光标位置跳至某行的起始位置

selection.MoveToLineAndOffset(startLine,10 )'将光标跳至某行的起始位置+10个字符处

selection.LineDown(True, 18) '将选择位置向下移18行,true表示将选择范围进行扩展,选择的起始位置不变,终止位置下移18行

selection.CharRight(True,5) ’与上面类似,将选择范围向右扩展5个字符

'VB语法输入多段文本只能用" & Chr(13) & _ 连接的方法

'在选择范围中进行文本替换

DTE.Find.Action = vsFindAction.vsFindActionReplaceAll

DTE.Find.Target = vsFindTarget.vsFindTargetCurrentDocumentSelection

DTE.Find.FindWhat = "dvxxxdv"

DTE.Find.ReplaceWith = keyword

DTE.Find.Execute()

DTE.Find.Target = vsFindTarget.vsFindTargetCurrentDocument '定义搜索范围,注意:默认是vsFindTargetCurrentDocumentSelection,只在当前选中文本中查找,vsFindTargetCurrentDocument表示全文查找

DTE.Find.Backwards = True '向上还是向下,默认居然是向上

DTE.Find.Action = vsFindAction.vsFindActionFind

DTE.Find.FindWhat = "{"

DTE.Find.Execute()

MsgBox(selection.Text.Trim())'弹出提示框

实例:

Imports System

Imports EnvDTE

Imports EnvDTE80

Imports EnvDTE90

Imports EnvDTE90a

Imports EnvDTE100

Imports System.Diagnostics

Public Module SkModule

'sk 2014.8.27 快速输入string.Format

Sub SQLFormat()

ActiveDocument.Selection.Text = "string.Format(@""select "",AisLogical.curUser);"

ActiveDocument.Selection.EndOfLine()

ActiveDocument.Selection.CharLeft(False, 23)

End Sub

'sk 2016.1.8将DataGridview控件加上两个事件替代selectionchanged事件

Sub DvAddFunc()

Dim selection As TextSelection = DTE.ActiveDocument.Selection

'选择整行,注意此时光标焦点落在下一行开始处

selection.SelectLine()

'取得整行文本

Dim keyword = selection.Text.Trim()

selection.Text = ""

'插入一行空白行

selection.NewLine()

'将光标移回到新空白行

selection.LineUp()

Dim startLine As Integer

'获取selection末端行号

startLine = selection.BottomPoint.Line

'VB语法输入多段文本只能用" & Chr(13) & _连接的方法

'注意在输入过程中VS环境可能会自动将某些看似语法错误的表达式替换成貌似正确的表达式,可能跟插入文本原文不一致

selection.Text = "//将下面两行剪切到该Dv控件所在窗体的Designer.cs文件中的InitializeComponent()函数末尾" & Chr(13) & _

"this.dvxxxdv.CellClick += new System.Windows.Forms.DataGridViewCellEventHandler(this.dvxxxdv_CellClick);" & Chr(13) & _

"this.dvxxxdv.KeyUp += new System.Windows.Forms.KeyEventHandler(this.dvxxxdv_KeyUp);" & Chr(13) & _

"public void zMySelectionChanged_dv()" & Chr(13) & _

"{" & Chr(13) & _

"if (dvxxxdv.SelectedRows.Count == 0) return;" & Chr(13) & _

"}" & Chr(13) & _

"private void dvxxxdv_CellClick(object sender, DataGridViewCellEventArgs e)" & Chr(13) & _

"{" & Chr(13) & _

"if (e.RowIndex < 0) return;//如果不是单击列表头" & Chr(13) & _

"zMySelectionChanged_dv();" & Chr(13) & _

"}" & Chr(13) & _

"" & Chr(13) & _

"private void dvxxxdv_KeyUp(object sender, KeyEventArgs e)" & Chr(13) & _

"{" & Chr(13) & _

"if (e.KeyData == Keys.Down || e.KeyData == Keys.Up)" & Chr(13) & _

"zMySelectionChanged_dv();            " & Chr(13) & _

"}" & Chr(13)

'将选择起始位置重新设回文本插入前的位置

selection.GotoLine(startLine)

selection.LineDown(True, 18)

'在选择范围中进行文本替换

DTE.Find.Action = vsFindAction.vsFindActionReplaceAll

DTE.Find.Target = vsFindTarget.vsFindTargetCurrentDocumentSelection

DTE.Find.FindWhat = "dvxxxdv"

DTE.Find.ReplaceWith = keyword

DTE.Find.Execute()

End Sub

'sk 2016.1.9将选择的范围加上#region结构

Sub AddRegion()

Dim selection As TextSelection = DTE.ActiveDocument.Selection '定义TextSelection 对象

Dim startLine As Integer

startLine = selection.TopPoint.Line

Dim endLine As Integer

endLine = selection.BottomPoint.Line

selection.GotoLine(startLine) '将光标位置跳至某行的起始位置

selection.Text = "#region" + Chr(13)

selection.GotoLine(endLine + 1) '将光标位置跳至某行的起始位置

selection.EndOfLine()

selection.NewLine()

selection.Text = "#endregion"

End Sub

'sk 2016.1.10将当前光标所在模块加上#region结构

Sub RegionOnBlock()

Dim selection As TextSelection = DTE.ActiveDocument.Selection '定义TextSelection 对象

Dim startline As Integer

startline = -1

Dim endline As Integer

endline = -1

Dim currentline As Integer = selection.ActivePoint.Line

selection.EndOfDocument() '将选择行移到最末一行

Dim documentlines As Integer = selection.ActivePoint.Line '整篇文档总行数

selection.GotoLine(currentline) '此时光标会停留在行首,如果加上,true参数整行将选择,选择的起始位置保持在行首和末尾

Dim kuohaoleft = 0 '从初始位置到当前位置共出现过几次{

selection.SelectLine()

selection.CharLeft(True)

Dim tx As String = selection.Text.Trim()

If (tx = "{") Then

kuohaoleft = 1

startline = selection.ActivePoint.Line

ElseIf (tx.IndexOf("{") >= 0) Then

MsgBox("光标所在行的'{'没有单独占一行,请重新选择行")

Return

Else

Do While kuohaoleft <= 0

'以下行为上移整行选择,选择的起始位置在行首和末尾,如果没有第句,选择末端会停留在下一行,也可用selection.GotoLine(xxline,true)实现

selection.LineUp()

selection.SelectLine()

selection.CharLeft(True)

tx = selection.Text.Trim()

If (tx = "{") Then

kuohaoleft += 1

ElseIf (tx = "}") Then

kuohaoleft -= 1

End If

If (selection.ActivePoint.Line = 1) Then Exit Do

Loop

If (kuohaoleft = 1) Then

startline = selection.ActivePoint.Line

Else

MsgBox("从当前位置以上没有出现单独一行的'{'")

Return

End If

End If

'此时光标停留在初始位置往上真实的第一个{处

kuohaoleft = 1 '其实运行到这里肯定kuohaoleft=1

Do While (kuohaoleft > 0)

selection.LineDown()

selection.SelectLine()

selection.CharLeft(True)

tx = selection.Text.Trim()

If (tx = "{") Then

kuohaoleft += 1

ElseIf (tx = "}") Then

kuohaoleft -= 1

End If

If (selection.ActivePoint.Line = documentlines) Then Exit Do

Loop

If (kuohaoleft = 0) Then

endline = selection.ActivePoint.Line

Else

MsgBox("从当前位置以下没有出现单独一行的'}'")

Return

End If

If (endline > startline And startline > 0) Then

selection.GotoLine(startline)

selection.EndOfLine()

selection.Text = Chr(13) + "#region"

selection.GotoLine(endline)

selection.EndOfLine()

selection.Text = Chr(13) + "#endregion"

'将光标放置到起始{行的末尾

selection.GotoLine(startline)

selection.EndOfLine()

End If

End Sub

End Module