AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / coding / 问题 / 79011427
Accepted
Alexandros
Alexandros
Asked: 2024-09-22 18:32:16 +0800 CST2024-09-22 18:32:16 +0800 CST 2024-09-22 18:32:16 +0800 CST

偏移另一个单元格的目标引用的最佳方法?

  • 772

假设我在单元格中有一个值$SheetX.A1(比如说数字 42)。

现在,我在另一个单元格中引用该值,比如$SheetY.M5通过将其内容设置为=$SheetX.A1(因此我在工作表 Y 的单元格 M5 中看到“42”)。

如何在另一个单元格中偏移 M5 所针对的引用?例如,我希望 M6 以 M5 所引用的相同位置为目标,偏移 6 行,换句话说,我希望 M6 显示$SheetX.A7(向下六行$SheetX.A1) 的值,因为这是 M5 所引用的。类似于“=OFFSET(TARGET(M5),6)”。

  • 我知道如果我可以使用 =INDIRECT("addr") 获取一个值
  • 我还知道我可以使用 =FORMULA(ref) 获取单元格的公式,因此=FORMULA(M5)将返回$SheetX.A1

我想我可以对其进行一些字符串操作以删除等号,然后修改尾随数字 1 以增加它,以某种方式生成我可以传递给的文本“$Sheet.A7” INDIRECT()?

怎样才能做到这一点?最好的方法是什么?

excel
  • 4 4 个回答
  • 55 Views

4 个回答

  • Voted
  1. Best Answer
    Ike
    2024-09-22T18:52:45+08:002024-09-22T18:52:45+08:00

    你可以尝试这个公式:

    =LET(start,M5,offsetRows,5,
    target,INDIRECT(MID(FORMULATEXT(start),2,LEN(FORMULATEXT(start))-1)),
    IF(ISERROR(target),"n.a.",OFFSET(target,offsetRows,0)
    ))
    

    如果公式返回有效结果,它将偏移INDIRECT- 否则它将返回 na (例如,如果公式在 D1 中=$SheetX.A1+1)

    • 2
  2. m-sarabi
    2024-09-22T19:01:58+08:002024-09-22T19:01:58+08:00

    您可以使用以下公式:

    =INDIRECT("'" & MID(FORMULATEXT(M1), 2, FIND("!", FORMULATEXT(M1)) - 2) & "'!" & ADDRESS(ROW(M1) + 6, COLUMN(A1)))
    

    它首先提取工作表,然后构建对当前行下方 6 行单元格的引用。

    • 2
  3. Harun24hr
    2024-09-22T18:58:52+08:002024-09-22T18:58:52+08:00

    我认为INDEX()应该SEQUENCE()可以。尝试-

    =INDEX(Sheet1!A1:A100,SEQUENCE(5,1,1,6))
    

    在此处输入图片描述

    • 1
  4. nkalvi
    2024-09-22T21:22:27+08:002024-09-22T21:22:27+08:00

    如果您有 Microsoft 365,则可以定义一个命名公式以方便使用:

    • INDIRECT通常人们不赞成使用,但在这里使用时要意识到这一点:)
    • 定义命名公式indirectOFFSET
    • ref可以是单个单元格或数组
    • 例如=indirectOFFSET(M5,6)或=indirectOFFSET(M5:M10,6,1)
    =LAMBDA(ref, [rows_], [cols_],
        LET(
            rows_, IF(ISOMITTED(rows_), 0, rows_),
            cols_, IF(ISOMITTED(cols_), 0, cols_),
            offset_one, LAMBDA(ref,
                LET(
                    ref_addr, IF(
                        ISREF(ref),
                        LET(f, FORMULATEXT(ref), RIGHT(f, LEN(f) - 1)),
                        NA()
                    ),
                    OFFSET(INDIRECT(ref_addr), rows_, cols_)
                )
            ),
            MAP(ref, offset_one)
        )
    )
    

    无需格式化,如在名称管理器中输入的:

    =LAMBDA(ref,[rows_],[cols_], LET(rows_, IF(ISOMITTED(rows_), 0, rows_), cols_, IF(ISOMITTED(cols_), 0, cols_), offset_one, LAMBDA(ref, LET(ref_addr, IF(ISREF(ref), LET(f, FORMULATEXT(ref), RIGHT(f, LEN(f) - 1)), NA()), OFFSET(INDIRECT(ref_addr), rows_, cols_))), MAP(ref, offset_one)))
    

    结果和命名公式

    • 1

相关问题

  • 如何返回列出的合同上有费率但系统中没有费率的特定行?

  • 当某些值重复时自动在表中添加参考字段?

  • 循环遍历具有更改单元格地址的列

  • 搜索字符串并输出与该字符串对应的值

  • Excel中有没有一种方法可以计算字符串中特定文本的出现次数,但也包括前一个字符?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Vue 3:创建时出错“预期标识符但发现‘导入’”[重复]

    • 1 个回答
  • Marko Smith

    为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行?

    • 1 个回答
  • Marko Smith

    具有指定基础类型但没有枚举器的“枚举类”的用途是什么?

    • 1 个回答
  • Marko Smith

    如何修复未手动导入的模块的 MODULE_NOT_FOUND 错误?

    • 6 个回答
  • Marko Smith

    `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它?

    • 3 个回答
  • Marko Smith

    何时应使用 std::inplace_vector 而不是 std::vector?

    • 3 个回答
  • Marko Smith

    在 C++ 中,一个不执行任何操作的空程序需要 204KB 的堆,但在 C 中则不需要

    • 1 个回答
  • Marko Smith

    PowerBI 目前与 BigQuery 不兼容:Simba 驱动程序与 Windows 更新有关

    • 2 个回答
  • Marko Smith

    AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String”

    • 1 个回答
  • Marko Smith

    我正在尝试仅使用海龟随机和数学模块来制作吃豆人游戏

    • 1 个回答
  • Martin Hope
    Aleksandr Dubinsky 为什么 InetAddress 上的 switch 模式匹配会失败,并出现“未涵盖所有可能的输入值”? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge 为什么这个简单而小的 Java 代码在所有 Graal JVM 上的运行速度都快 30 倍,但在任何 Oracle JVM 上却不行? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini 具有指定基础类型但没有枚举器的“枚举类”的用途是什么? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(表达式,左值) = 右值` 在 C 或 C++ 中是有效的赋值吗?为什么有些编译器会接受/拒绝它? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer 何时应使用 std::inplace_vector 而不是 std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller 在 5.2 版中,bash 条件语句中的 [[ .. ]] 中的分号现在是可选的吗? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench 为什么双破折号 (--) 会导致此 MariaDB 子句评估为 true? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng 为什么 `dict(id=1, **{'id': 2})` 有时会引发 `KeyError: 'id'` 而不是 TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob:MobileAds.initialize() - 对于某些设备,“java.lang.Integer 无法转换为 java.lang.String” 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB 为什么 GCC 生成有条件执行 SIMD 实现的代码? 2024-02-17 06:17:14 +0800 CST

热门标签

python javascript c++ c# java typescript sql reactjs html

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve