Andrey Asked:2020-06-06 03:39:21 +0000 UTC2020-06-06 03:39:21 +0000 UTC 2020-06-06 03:39:21 +0000 UTC 排序后如何将表格恢复到原始状态? 772 我模拟这种情况。假设我们有一张桌子: 按项目名称打开过滤器(隐藏“A”以外的所有内容): 接下来,对列 G“名称”(A - Z)进行排序: 删除项目名称过滤器(选择“显示全部”): 结果,带有“A”项的行仍然按名称排序! 如何将表格返回到其原始位置(没有过滤器和排序)??? PS回滚(Ctrl + Z)不适合。 excel 1 个回答 Voted Best Answer vikttur_Stop_RU_war_in_UA 2020-06-06T03:57:05Z2020-06-06T03:57:05Z 为了回到原来的状态,你需要以某种方式记住这个状态。如果没有任何可以用来确定表格初始状态的指针(标准、标志、数字等),任何事情都不会起作用。 “内存”可以是具有行号的列。 在编号的第一列中,在带有排序/过滤的操作之前,将公式替换为值。如果由于某种原因,公式应该保留(例如,过滤行的序列号),则将编号放在单独的列中。 按此列升序排序,首先展开所有过滤器。 如果完全“没有过滤器和排序”,如问题所示,那么只需编写一个脚本(对于Excel - 在VBA中,对于Google -sheets - 在JavaScript中)。但是宏也不是万能的,还需要告诉它怎么排线。 '----------------------------- 为了使可见行编号的公式不会中断并正常工作,必须将带有公式的列“撕掉”——不要在过滤器中包含该列。可以肯定的是,公式可以与具有空列过滤器的表分开。 计算可见单元格中值的公式: =ПРОМЕЖУТОЧНЫЕ.ИТОГИ(3;$C$2:C2) =SUBTOTAL(3;$C$2:C2)
为了回到原来的状态,你需要以某种方式记住这个状态。如果没有任何可以用来确定表格初始状态的指针(标准、标志、数字等),任何事情都不会起作用。
“内存”可以是具有行号的列。
在编号的第一列中,在带有排序/过滤的操作之前,将公式替换为值。如果由于某种原因,公式应该保留(例如,过滤行的序列号),则将编号放在单独的列中。
按此列升序排序,首先展开所有过滤器。
如果完全“没有过滤器和排序”,如问题所示,那么只需编写一个脚本(对于Excel - 在VBA中,对于Google -sheets - 在JavaScript中)。但是宏也不是万能的,还需要告诉它怎么排线。
'-----------------------------
为了使可见行编号的公式不会中断并正常工作,必须将带有公式的列“撕掉”——不要在过滤器中包含该列。可以肯定的是,公式可以与具有空列过滤器的表分开。
计算可见单元格中值的公式: