首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >宏程序不会只运行一次continuously...Run

宏程序不会只运行一次continuously...Run
EN

Stack Overflow用户
提问于 2019-02-14 12:32:31
回答 1查看 43关注 0票数 0

我是用excel进行宏编程的新手,我想在输入数据后对A列进行连续排序。但它不起作用。它排序一次,然后停止。你能帮我解决这个问题吗?非常感谢..。

代码语言:javascript
复制
Sub Macro3(ByVal Target As Range)
ActiveWorkbook.Worksheets("Sheet1").ListObjects("Table1").sort.SortFields.Clear
ActiveWorkbook.Worksheets("Sheet1").ListObjects("Table1").sort.SortFields.Add _
    Key:=Range("A2"), SortOn:=xlSortOnValues, Order:=xlAscending, DataOption _
    :=xlSortNormal
With ActiveWorkbook.Worksheets("Sheet1").ListObjects("Table1").sort
    .Header = xlYes
    .MatchCase = False
    .Orientation = xlTopToBottom
    .SortMethod = xlPinYin
    .Apply
End With
End Sub

Sub sort()
Dim Target As Range
Set Target = Range("Table1")
Call Macro3(Target)
End Sub

Private Sub Worksheet_Change(ByVal Target As Range)
If Not Intersect(Target, Range("A:A")) Is Nothing Then
Call sort
End If
End Sub
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-02-14 13:08:43

在对工作表上的值进行更改之前,需要禁用事件处理。

代码语言:javascript
复制
Option Explicit

Private Sub Worksheet_Change(ByVal Target As Range)
    If Not Intersect(Target, Range("A:A")) Is Nothing Then
        On Error GoTo out_here
        Application.EnableEvents = False
        With ListObjects("Table1").Range
            .Sort key1:=.Cells(1), order1:=xlAscending, _
                  Header:=xlYes
        End With
    End If

out_here:
        Application.EnableEvents = True
End Sub

这就是执行任务所需的全部内容。如果您想将排序代码分成三个部分,只要您保留禁用事件处理,这应该是一件简单的事情。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54683260

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档