广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    EXCEL中将复制的内容粘贴到可见单元格

    来源:网络收集  点击:  时间:2024-08-24
    【导读】:
    EXCEL中可以通过设置(快捷方式Ctrl+G)定位--定位条件--可见单元格来选择并复制可见单元格,但是如果将复制的单元格粘贴到包含隐藏单元格的区域时,EXCEL不会自动跳过这些隐藏的单元格,影响编辑效果。通过以下方法可以实现只对可见的单元格进行复制和粘贴的操作。工具/原料more各版本EXCEL方法/步骤1/7分步阅读

    本方法要使用EXCEL VBA宏代码进行操作,代码如下:

    Option Explicit

    Sub 复制粘贴可见单元格()

    Dim rgSrc As Range

    Dim rgDes As Range

    Dim rg As Range, rgPt As Range

    Dim strSrcAdd() As String

    Dim lCnt As Long, i As Long, j As Long, x As Long, y As Long

    On Error GoTo ExitPoint

    Set rgSrc = Application.InputBox(请选择要复制的单元格区域, 提示, , , , , , 8)

    If rgSrc.Columns.Count rgSrc.Parent.UsedRange.Columns.Count Then

    Set rgSrc = rgSrc.Parent.Range(rgSrc.Item(1, 1), rgSrc.Item(rgSrc.Rows.Count, rgSrc.Parent.UsedRange.Columns.Count))

    End If

    If rgSrc.Rows.Count rgSrc.Parent.UsedRange.Rows.Count Then

    Set rgSrc = rgSrc.Parent.Range(rgSrc.Item(1, 1), rgSrc.Item(rgSrc.Parent.UsedRange.Rows.Count, rgSrc.Columns.Count))

    End If

    Set rgDes = Application.InputBox(请选择要粘贴的单元格位置, 提示, , , , , , 8)

    Application.ScreenUpdating = False

    Application.Calculation = xlCalculationManual

    Set rgPt = rgDes.Cells(1, 1)

    ReDim strSrcAdd(0)

    For Each rg In rgSrc

    If Not (rg.Height = 0 Or rg.Width = 0) Then

    ReDim Preserve strSrcAdd(UBound(strSrcAdd) + 1)

    strSrcAdd(UBound(strSrcAdd)) = rg.Address

    End If

    Next rg

    lCnt = 0

    For Each rg In rgSrc.Parent.Range((rgSrc.Rows(1).Address))

    If rg.Width 0 Then

    lCnt = lCnt + 1

    End If

    Next

    strSrcAdd(0) = lCnt

    i = 0

    j = 0

    x = 0

    y = 0

    For lCnt = 1 To UBound(strSrcAdd)

    lp: If ((lCnt - 1) \ strSrcAdd(0)) + i x Then

    j = 0

    End If

    x = ((lCnt - 1) \ strSrcAdd(0)) + i

    y = ((lCnt - 1) Mod strSrcAdd(0)) + j

    Set rg = rgPt.Offset(x, y)

    If rg.Width = 0 Then

    j = j + 1

    GoTo lp

    ElseIf rg.Height = 0 Then

    i = i + 1

    j = 0

    GoTo lp

    Else

    rg.Value = rgSrc.Parent.Range(strSrcAdd(lCnt))

    End If

    Next lCnt

    rgDes.Parent.Activate

    ExitPoint:

    Application.ScreenUpdating = True

    Application.Calculation = xlCalculationAutomatic

    End Sub

    下面将以一个示例的方式,演示如何使用以上代码。

    2/7

    图中标黄色的为要隐藏的单元格,隐藏前后效果如图所示。

    3/7

    在相应的工作表上点击右键,在弹出的窗口中选择“查看代码”

    4/7

    在打开的VBE界面中粘贴以上复制的代码。

    5/7

    在“查看宏”对话框中选择并运行名为“复制粘贴可见单元格”的宏。宏的使用方法,请另外百度。

    6/7

    先选择要复制的单元(也可以是整行或整列),然后选择要粘贴的单元格位置(可以多选,也可以只选一个,都是以选择区域的活动单元为开始粘贴位置)。

    7/7

    粘贴完成后对比效果如下图,宏只对可见的单元格进行了操作。

    注意事项

    不可以跨工作簿操作

    excel
    本文关键词:

    版权声明:

    1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

    2、本站仅提供信息发布平台,不承担相关法律责任。

    3、若侵犯您的版权或隐私,请联系本站管理员删除。

    4、文章链接:http://www.1haoku.cn/art_1153382.html

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-07 04:17:57  耗时:0.028
    0.0277s