9.1 剪切、复制和粘贴来移动数据

sourceRange.Cut [Destination]

如果指定Destination,相当于Ctrl^X(sourceRange) & Ctrl^V(Destination)。如果没有指定就相当于Ctrl^X(sourceRange)。

sourceRange.Copy [Destination]

如果指定Destination,相当于Ctrl^C(sourceRange) & Ctrl^V(Destination)。如果没有指定就相当于Ctrl^C(sourceRange)。

Application.CutCopyMode = False 可以关闭cut/copy时,单元格周围移动的虚线框。

destinationRange.PasteSpecial

[paste as xlPasteType],

[operation as xlPasteSpecialOperation],

[SkipBlanks as boolean],

[Transpose]

其中:

Paste := [xlPasteAll]|xlPasteAllExceptBorders|xlPasteColumnWidths|xlPasteComments|xlPasteFormats|xlPasteFormulas

|xlPasteFormulasAndNumberFormats|xlPasteValidation|xlPasteValues|xlPasteValuesAndNumberFormats

operation := [xlPasteSpecialOperationNone]|xlPasteSpecialOperationAdd|xlPasteSpecialOperationDivide|xlPasteSpecialOperationMultiply|xlPasteSpecialOperationSubstract

operation 指的是是否对源范围内的数值进行简单的算术运算。

skipBlanks 指是否忽略源范围的空白单元格,默认是False,不忽略。

Transpose 指是否转置,默认为False,不转置。

rangeToDelete.Delete [Shift as XlDeleteShiftDirection]

其中:

Shift := xlShiftToLeft | xlShiftUp。Used only with Range objects. Specifies how to shift cells to replace deleted cells. Can be one of the following XlDeleteShiftDirection constants: xlShiftToLeft or xlShiftUp. If this argument is omitted, Microsoft Excel decides based on the shape of the range.

9.2 查找我们的目标

expression.Find(What, After, LookIn, LookAt, SearchOrder, SearchDirection, MatchCase, MatchByte, SearchFormat)

参见:http://msdn.microsoft.com/en-us/library/ff839746(v=office.15).aspx

expression.FindNext(After)

expression.FindPrevious(After)

参见:http://msdn.microsoft.com/en-us/library/ff196143(v=office.15).aspx

以及:http://msdn.microsoft.com/en-us/library/ff838614(v=office.15).aspx

代码清单9.1:使用Find和Copy方法

'name of worksheet
Private Const WORKSHEET_NAME = "Find Example" 'Name of range used to flag beginning of found list
Private Const FOUND_LIST = "FoundList" 'Name of range that contains the product look for
Private Const LOOK_FOR = "LookFor" Sub FindExample()
Dim ws As Worksheet
Dim rgSearchIn As Range
Dim rgFound As Range
Dim sFirstFound As String
Dim bContinue As Boolean ResetFoundList
Set ws = ThisWorkbook.Worksheets(WORKSHEET_NAME)
bContinue = True
Set rgSearchIn = GetSearchRange(ws) 'find the first instance of DLX
'looking at all cells on the worksheet
'looking at the whole contents of the cell
Set rgFound = rgSearchIn.Find(ws.Range(LOOK_FOR).Value, xlValue, xlWhole) 'if we found something, remember where we found it
'this is needed to terminate the do...loop later on
If Not rgFound Is Nothing Then sFirstFound = rgFound.Address Do Until rgFound Is Nothing Or Not bContinue
CopyItem rgFound 'find the next instance starting with the
'cell after the one we just found
Set rgFound = rgSearchIn.FindNext(rgFound) 'FindNext doesn 't automatically stop when it
'reaches the end of the worksheet - rather
'it wraps around to the beginning again.
'we need to prevent an endless loop by stopping
'the process once we find something we've already found
If rgFound.Address = sFirstFound Then bContinue = False
Loop Set rgSearchIn = Nothing
Set rgFound = Nothing
Set ws = Nothing
End Sub 'sets a range reference to the range containing the list - the product column
Private Function GetSearchRange(ws As Worksheet) As Range
Dim lLastRow As Long lLastRow = ws.Cells(, ).End(xlUp).Row
Set GetSearchRange = ws.Range(ws.Cells(, ), ws.Cells(lLastRow, ))
End Function 'copies item to found list range
Private Sub CopyItem(rgItem As Range)
Dim rgDestination As Range
Dim rgEntireItem As Range 'need to use a new range object because
'we will be altering this reference.
'altering the reference would screw up
'the find next process in the findExample
'procedure. also - move off of header row
Set rgEntireItem = rgItem.Offset(, -) 'resize reference to consume all four columns associated with the found item
Set rgEntireItem = rgEntireItem.Resize(, ) 'set initial reference to found list
Set rgDestination = rgItem.Parent.Range(FOUND_LIST) 'find first empty row in found list
If IsEmpty(rgDestination.Offset(, )) Then
Set rgDestination = rgDestination.Offset(, )
Else
Set rgDestination = rgDestination.End(xlDown).Offset(, )
End If 'copy the item to the found list
rgEntireItem.Copy rgDestination
Set rgDestination = Nothing
Set rgEntireItem = Nothing
End Sub 'clears contents from the found list range
Private Sub ResetFoundList()
Dim ws As Worksheet
Dim lLastRow As Long
Dim rgTopLeft As Range
Dim rgBottomRight As Range Set ws = ThisWorkbook.Worksheets(WORKSHEET_NAME)
Set rgTopLeft = ws.Range(FOUND_LIST).Offset(, )
lLastRow = ws.Range(FOUND_LIST).End(xlDown).Row
Set rgBottomRight = ws.Cells(lLastRow, rgTopLeft.Offset(, ).Column) ws.Range(rgTopLeft, rgBottomRight).ClearContents Set rgTopLeft = Nothing
Set rgBottomRight = Nothing
Set ws = Nothing
End Sub

9.3 使用Replace替换

expression.Replace(What, Replacement, LookAt, SearchOrder, MatchCase, MatchByte, SearchFormat, ReplaceFormat)

参见:http://msdn.microsoft.com/en-us/library/ff194086(v=office.15).aspx

代码清单9.2:使用Replace以程序设计的方式设置正确的范围

Sub ReplaceExample()
Dim ws As Worksheet
Dim rg As Range
Dim lLastRow As Long Set ws = ThisWorkbook.Worksheets("Replace Examples") 'determine last cell in data range
'assumes the would never be an empty cell
'in column 1 at the bottom of the list
lLastRow = ws.Cells(, ).End(xlUp).Row 'Replace empty cells in 2nd & 3rd columns
Set rg = ws.Range(ws.Cells(, ), ws.Cells(lLastRow, ))
rg.Replace "", "UNKNOWN" 'Replace empty cells in 4th column
Set rg = ws.Range(ws.Cells(, ), ws.Cells(lLastRow, ))
rg.Replace "", "" Set rg = Nothing
Set ws = Nothing
End Sub

代码清单9.3:使用Replace替换格式

Sub ReplaceFormats()
'set formatting to look for
With Application.FindFormat
.Font.Bold = True
.Font.Size =
End With 'set formatting that should be applied instead
With Application.ReplaceFormat
.Font.Bold = False
.Font.Italic = True
.Font.Size =
End With ActiveSheet.Cells.Replace What:="", Replacement:="", SearchFormat:=True, ReplaceFormat:=True
End Sub

9.4 喜欢它的特别调味品吗?

expression.SpecialCells(Type, Value)

参见:http://msdn.microsoft.com/en-us/library/ff196157(v=office.15).aspx

代码清单9.4:当使用SpecialCells时,使用错误处理

Sub SpecialCells()
Dim ws As Worksheet
Dim rgSpecial As Range
Dim rgCell As Range
On Error Resume Next Set ws = ThisWorkbook.Worksheets("Special Cells")
Set rgSpecial = ws.Cells.SpecialCells(xlCellTypeFormulas, xlErrors) If Not rgSpecial Is Nothing Then
rgSpecial.Interior.Color = vbRed
Else
MsgBox "congratulations! " & ws.Name & " is an error-free worksheet."
End If Set rgSpecial = Nothing
Set rgCell = Nothing
Set ws = Nothing
End Sub

9.5 CurrentRegion:一个有用的捷径

Range对象的CurrentRegion属性

参见:http://msdn.microsoft.com/en-us/library/ff196678(v=office.15).aspx

Range对象的ListHeaderRows属性

参见:http://msdn.microsoft.com/en-us/library/ff839644(v=office.15).aspx

代码清单9.5:调用CurrentRegion观察一个列表的有用特征

Sub CurrentRegionExample()
Dim ws As Worksheet
Dim rg As Range Set ws = ThisWorkbook.Worksheets("Current Region") 'get current regionassociated with cell A1
Set rg = ws.Cells(, ).CurrentRegion 'number of header rows
ws.Range("I2").Value = rg.ListHeaderRows 'number of columns
ws.Range("I3").Value = rg.Columns.Count 'resize to exclude header rows
Set rg = rg.Resize(rg.Rows.Count - rg.ListHeaderRows, rg.Columns.Count).Offset(, ) 'number of rows ex header rows
ws.Range("I4").Value = rg.Rows.Count 'number of cells ex header rows
ws.Range("I5").Value = rg.Cells.Count 'number empty cells ex header rows
ws.Range("I6").Value = Application.WorksheetFunction.CountBlank(rg) 'number of numeric cells ex header rows
ws.Range("I7").Value = Application.WorksheetFunction.Count(rg) 'last row
ws.Range("I8").Value = rg.Rows.Count + rg.Cells(, ).Row - Set rg = Nothing
Set ws = Nothing
End Sub

9.6 列表简单排序

expression.Sort(Key1, Order1, Key2, Type, Order2, Key3, Order3, Header, OrderCustom, MatchCase, Orientation, SortMethod, DataOption1, DataOption2, DataOption3)

参见:http://msdn.microsoft.com/en-us/library/ff840646(v=office.15).aspx

中文排序:

expression.SortSpecial(SortMethod, Key1, Order1, Type, Key2, Order2, Key3, Order3, Header, OrderCustom, MatchCase, Orientation, DataOption1, DataOption2, DataOption3)

参见:http://msdn.microsoft.com/en-us/library/ff822807(v=office.15).aspx

代码清单9.6:增加工作表列表的可单击排序

Dim mnDirection As Integer
Dim mnColumn As Integer Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
'make sure the double-click occurred in a cell
'containing column labels
If Target.Column < And Target.Row = Then
'see if we need to toggle the direction of the sort
If Target.Column <> mnColumn Then
'clicked in new column - record 'which column was clicked
mnColumn = Target.Column
'set default direction
mnDirection = xlAscending
Else
'clicked in same column toggle the sort direction
If mnDirection = xlAscending Then
mnDirection = xlDescending
Else
mnDirection = xlAscending
End If
End If
TestSort
End If
End Sub Private Sub TestSort()
Dim rg As Range 'get current region associated with cell A1
Set rg = Me.Cells(, ).CurrentRegion 'ok - sort the list
rg.Sort key1:=rg.Cells(, mnColumn), order1:=mnDirection, Header:=xlYes Set rg = Nothing
End Sub

9 Range 实用操作的更多相关文章

  1. 提高开发效率的 Eclipse 实用操作

    工欲善其事,必先利其器.对于程序员来说,Eclipse便是其中的一个“器”.本文会从Eclipse快捷键和实用技巧这两个篇章展开介绍.Eclipse快捷键用熟后,不用鼠标,便可进行编程开发,避免鼠标分 ...

  2. input中range相关操作

    利用mousover触发函数对range的操作练习 <!DOCTYPE html> <html> <head> <meta charset="utf ...

  3. Chrome 开发者工具实用操作

    Chrome 开发者工具实用操作 https://umaar.com/dev-tips/

  4. KiCAD实用操作

    KiCAD实用操作之一:自动编辑线宽 今天偶然间发现的一个比较实用的功能,算是KiCAD的一个优点吧(或许是在AD上面没发现):当整个PCB布完线或者在布线过程中,我们有可能需要对某个线的宽度进行调整 ...

  5. 能够提高开发效率的Eclipse实用操作

    工欲善其事,必先利其器.对于程序员来说,Eclipse便是其中的一个“器”.本文会从Eclipse快捷键和实用技巧这两个篇章展开介绍.Eclipse快捷键用熟后,不用鼠标,便可进行编程开发,避免鼠标分 ...

  6. 能够提高开发效率的 Eclipse 实用操作

    工欲善其事,必先利其器.对于程序员来说,Eclipse便是其中的一个“器”.本文会从Eclipse快捷键和实用技巧这两个篇章展开介绍.Eclipse快捷键用熟后,不用鼠标,便可进行编程开发,避免鼠标分 ...

  7. VS2019 实用操作

    本文列出了在编写程序过程中的几个非常实用的操作方式,通过这些操作方式,可以在一定程度上减少重复操作.提高编码效率.改善编程体验. 列模式操作 列操作是一项很常用且实用的功能,可以一次性修改不同的行. ...

  8. Netcat实用操作

    写久了web倦了,第n次开始尝试网络开发,于是熟悉一下常用工具. 尝试了一下netcat来测试服务器,或者充当客户端都异常好用.于是记录一下常用的一下命令 1. 充当服务器,或者客户端进行访问 通过n ...

  9. Myeclipse学习总结(8)——Eclipse实用操作

    工欲善其事,必先利其器.对于程序员来说,Eclipse便是其中的一个"器".本文会从Eclipse快捷键和实用技巧这两个篇章展开介绍.Eclipse快捷键用熟后,不用鼠标,便可进行 ...

随机推荐

  1. shell脚本、if语句、for循环语句

    shell在shell脚本中,如果用户不输入东西,系统不自动退出,this is a bug!文件测试语句:-d -f -r -w -x -e逻辑测试语句:“&&”与(同时满足) “| ...

  2. win10永久激活

    现在我们可以看下当前系统的激活状态,查看方法"WIN+R"打开运行对话框,输入命令slmgr.vbs -xpr,点击确定,这样可以查看到当前系统的激活信息.大家可以发现,虽然小编系 ...

  3. Python之粘包

    Python之粘包 让我们基于tcp先制作一个远程执行命令的程序(1:执行错误命令 2:执行ls 3:执行ifconfig) 注意注意注意: res=subprocess.Popen(cmd.deco ...

  4. mac 文本处理命令分享

    mac 文本处理命令分享 */--> pre.src {background-color: #292b2e; color: #b2b2b2;} pre.src {background-color ...

  5. Discuz论坛广告横幅大图在百度app内无法显示,百度app默认开启了广告屏蔽

    问题由来 前段时间搭的一个Discuz论坛上挂了2个广告横幅,网站的话收录还不错,然后客户就反应百度app上无法看到横幅. 由于我没有下载百度app,看不到效果我将信将疑,因为电脑,手机浏览器都是ok ...

  6. java的动态代理机制详解-----https://www.cnblogs.com/xiaoluo501395377/p/3383130.html

    java的动态代理机制详解-----https://www.cnblogs.com/xiaoluo501395377/p/3383130.html

  7. xtu summer individual 6 B - Number Busters

    Number Busters Time Limit: 1000ms Memory Limit: 262144KB This problem will be judged on CodeForces. ...

  8. 权限管理组件:rbac

    rbac: Role_Based Access Control,基于角色的权限控制 权限:一个包含正则表达式 的url就是一个权限 目录结构: rbac这个app中的文件代码如下: rbac/mode ...

  9. [cf360 div1.C]The Values You Can Make[Dp]

    题意:有n个硬币,面值不同,求能组成K的方案中,每个方案的硬币可以凑成那些答案. 例如, K=5 面值={1,1,1,2,3} K={1,1,1,2} K={1,1,3} K={2,3} 那么答案是 ...

  10. Mycat集群方案收集(待实践)

    先收集,后续再实践. 我想,市面上开源方案中,涉及到高可用和负载均衡的部署,无论是哪一个产品应用,都基本离不开LVS+Keepalived+HAProxy+Nginx等等. 下面是收集的教程: htt ...