RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1283667
Accepted
2b4fITin
2b4fITin
Asked:2022-05-19 18:16:17 +0000 UTC2022-05-19 18:16:17 +0000 UTC 2022-05-19 18:16:17 +0000 UTC

通过指定参数将字符串选择到数组中

  • 772

同事!将字符串从数组输出到新工作表时,代码(超出范围)崩溃(我什至不确定数组的形成是否一切正常):

Sub BKFindDeviations()

Dim Deviations() As Variant
Dim rng As Range
Dim Mnth1 As Date
Dim Mnth2 As Date
Dim MnthRowCounter As Long
Dim LoopCounter As Long
Dim r As Range
Dim k As Long

Application.ScreenUpdating = False
Application.Calculation = xlCalculationManual

Mnth1 = "01.01.2020" 'Mnth1 = InputBox("Ââåäèòå ïåðâîå ÷èñëî ìåñÿöà, êîòîðûé áóäåò ñðàâíèâàòüñÿ ñ ïðîøëûìè ìåñÿöàì (ôîðìàò: dd.mm.yyyy")
Mnth2 = "01.02.2020" 'Mnth2 = InputBox("Ââåäèòå ïåðâîå ÷èñëî ìåñÿöà, êîòîðûé áóäåò ÿâëÿòüñÿ áàçîé äëÿ ñðàâíåíèÿ (ôîðìàò: dd.mm.yyyy")

For Each r In Range("a1", Range("a1").End(xlDown))
    If r.Offset(0, 8).Value = Mnth1 Or r.Offset(0, 8).Value = Mnth2 Then
        MnthRowCounter = MnthRowCounter + 1
        ReDim Preserve Deviations(1 To 17, 1 To MnthRowCounter)
        For LoopCounter = 1 To 17 'Range("a1", Range("a1").End(xlToRight))
            Deviations(LoopCounter, MnthRowCounter) = r.Offset(0, LoopCounter - 1).Value
        Next LoopCounter
    End If
Next r

'Deviations = Range("a1", Range("a1").End(xlToRight).End(xlDown))

Worksheets.Add

Range(ActiveCell, ActiveCell.Offset(UBound(Deviations, 1) - 1, UBound(Deviations, 2) - 1)).Value = Deviations

Erase Deviations

Set rng = Range("a1", Range("a1").End(xlDown).End(xlToRight))

'×èñòèì ôîðìàò
With rng
    .ClearFormats
End With

'Óñòàíàâëèâàåì ôîðìàò "Äàòà" â ñòîëáöå Äàò
For k = 1 To Cells(Rows.Count, 9).End(xlUp).Row
    'If Cells(r, 9) Like "##.##.####" Then
        'Cells(r, 9) = DateSerial(Right(Cells(r, 9), 4), Mid(Cells(r, 9), 4, 2), Left(Cells(r, 9), 2))
        Cells(k, 9).NumberFormat = "dd.mm.yyyy;@"
    'End If
Next k

Application.ScreenUpdating = True
Application.Calculation = xlCalculationAutomatic End Sub

“出发”前算子所涉及的变量值:

在此处输入图像描述

更新了代码

excel
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    JohnSUN
    2022-05-19T20:50:25Z2022-05-19T20:50:25Z

    我仍然建议现在改用自动过滤器 - 它会变得更短更容易,而且 - 我认为如此 - 更可靠

    Sub BKFindDeviations()
    Dim Mnth1 As String, Mnth2 As String
    Dim aRng As Range, aDest As Range
    
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
    
    Mnth1 = "01.01.2020" ' Или с помощью InputBox()
    Mnth2 = "01.02.2020"
        Set aRng = Range("A1").CurrentRegion
        Worksheets.Add After:=Worksheets(Worksheets.Count)
        Set aDest = Worksheets(Worksheets.Count).Range("A1")
        aRng.AutoFilter
        aRng.AutoFilter Field:=10, Criteria1:="=" & Mnth1, Operator:=xlOr, Criteria2:="=" & Mnth2
        aRng.SpecialCells(xlCellTypeVisible).Copy Destination:=aDest
        Application.CutCopyMode = False
        aRng.AutoFilter
    Application.Calculation = xlCalculationAutomatic
    Application.ScreenUpdating = True
    End Sub
    

    当然,您可以逐行浏览每一行,选择后续复制所需的行。例如,可以这样做:

    Sub BKFindDeviations()
        Dim aRows() As Long
        Dim srcSheet As Worksheet
        Dim src As Range
        Dim aCell As Range
        Dim Mnth1 As Date
        Dim Mnth2 As Date
        Dim MnthRowCounter As Long
        Dim LoopCounter As Long
        
        Application.ScreenUpdating = False
        Application.Calculation = xlCalculationManual
        
        Mnth1 = "01.01.2020"
        Mnth2 = "01.02.2020"
        Set srcSheet = ActiveSheet
        Set src = srcSheet.Range("A1").CurrentRegion
        For Each aCell In Intersect(srcSheet.Columns(9), src).Cells
            If aCell.Value = Mnth1 Or aCell.Value = Mnth2 Then
                MnthRowCounter = MnthRowCounter + 1
                ReDim Preserve aRows(1 To MnthRowCounter)
                aRows(MnthRowCounter) = aCell.Row
            End If
        Next aCell
        
        Worksheets.Add
        Set aCell = ActiveSheet.Range("A1")
        src.Rows(1).Copy Destination:=aCell ' Строка заголовков
        Set aCell = aCell.Offset(1, 0)
        For LoopCounter = LBound(aRows) To UBound(aRows)
            src.Rows(aRows(LoopCounter)).Copy Destination:=aCell
            Set aCell = aCell.Offset(1, 0)
        Next LoopCounter
        Erase aRows
        Columns.AutoFit
        Application.Calculation = xlCalculationAutomatic
        Application.ScreenUpdating = True
    End Sub
    
    • 1

相关问题

  • 使用 VBA 在 Excel 中插入图片

  • 选择哪里(EXCEL)

  • 两列的条件格式

  • 如何按文章比较两个表格?

  • 打开工作簿时,跳转到当前日期的单元格[关闭]

  • 在工作簿之间复制数据。WBA代码加速

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5