gpt4 book ai didi

google-sheets - 仅嵌入一系列可编辑的Google电子表格

转载 作者:行者123 更新时间:2023-12-04 19:43:39 26 4
gpt4 key购买 nike

我有一个Google电子表格,我给我的每个用户一个他们可以编辑的小范围(实际上只是他们自己的行)。现在,我想使用iframe嵌入此工作表。如何只嵌入一系列可编辑的电子表格?此行根据需要显示所需的范围,但是由于存在“ pubhtml?”,因此无法进行编辑:

src =“ https://docs.google.com/spreadsheets/d/1mjKXUsDs9EfqV9WztdfmNLm-sZwhphTieqEoBEHWce4/pubhtml?gid=0&single=true&widget=true&headers=false&range=a1%3Ah5&widget=false

当我只更改“ pubhtml?”时进行“编辑?”,这些用户就可以对其进行编辑,但是它向我显示了整个工作表,包括标题等:

src =“ https://docs.google.com/spreadsheets/d/1mjKXUsDs9EfqV9WztdfmNLm-sZwhphTieqEoBEHWce4/edit?gid=0&single=true&widget=true&headers=false&range=a1%3Ah5&widget=false&chrome

我可以找到许多用于嵌入的参数的(令人困惑的)信息,但是找不到此问题的答案。还是不可能?
(注意:我确实找到了两个类似的问题,但是它们没有回答我的问题-也许我听不懂答案?:-)

谢谢,
斯蒂夫

最佳答案

嵌入Google表格似乎并不像人们希望的那样直观。但是一些研究(记住,Google是您的朋友,除非您的名字与Rump押韵,除非经过反复尝试)为您的问题提供了解决方案。

OP的计划是为每个用户提供访问其自己的行以进行数据输入的权限。人们可能会想到可以/将要完成的几种方法。 (对我而言)最明显的是简单地使用户访问主表上的“其行”-例如,“用户A”可以访问第53行,“用户B”可以访问第17行等等。这非常容易做到(我们将看到),但是值得/重要的是用户还应该看到列标题。例如,如果列标题位于第1行,则“用户A”需要访问第1行和第53行。问题!我们可以访问连续的行,但不能访问两个离散的范围。因此,这种方法根本不可能-或至少我找不到实现它的方法。

我采用的方法是从母版纸开始。然后为每个用户添加一张额外的纸。例如,我们添加工作表“用户A”,“用户B”,依此类推。每个“用户表”只有两行数据。第1行包含列标题,第2行包含用户数据-这使我们可以连续访问用户的两个连续行。主表中的单元格从包含手工输入/硬编码的数据变为链接到适当用户表上适当列的简单公式。

我认为授予每个用户访问自己行的权限是不明智的(但是可以这样做)。我认为,各种安全隐患并不能证明存在风险。我的强烈建议是每个用户都应该有自己的工作表(即每个用户一个单独的文档)。然后,用户只能访问该工作表中有限数量的行,并且主工作表(这是一个单独的文件)包含用于在用户工作表(也是一个单独的文件)中提取数据的公式。使用这种方法,如果用户设法“向上推”(无论/何时/何地-但您只知道它会发生),则仅影响他们的工作表(以及指向母版的链接)。这与使整个主电子表格处于风险之中的方法相比。

为了完整起见,我建议解决各种选择-听起来可能很令人厌烦。
为了参考起见,我创建了一个Google工作表(so_46059687)作为OP主表的替代。

不可编辑的嵌入-(版本1)
在此示例中,可以看到但不能编辑母版表。该文档包括两个“用户”表,但这些页面不可见(通过选择)。

我发现Google论坛中的两个文档“ Embed Sheet and remove Titles and Scrolling bars”和“ How to I edit the height/width of a google sheets embed code when embedding it on my website?”非常有用

Codepen example

<iframe width="100%" height="250" src="https://docs.google.com/spreadsheets/d/e/2PACX-1vR-1keK8Wmyr4V6o6cjskLCetvsmbLeMsJuZViPpqkPck2-P2kCb4E4Ta_YMjbawz4lfgU_LVPFuqya/pubhtml?gid=0&amp;single=true&amp;widget=true&amp;headers=false"></iframe>




不可编辑的嵌入-(第2版)
这是版本1的主题的变体,只是使其中一个用户表可见。第二个用户表不可见(通过选择)。

Codepen example

<iframe width="100%" height="250" src="https://docs.google.com/spreadsheets/d/e/2PACX-1vR-1keK8Wmyr4V6o6cjskLCetvsmbLeMsJuZViPpqkPck2-P2kCb4E4Ta_YMjbawz4lfgU_LVPFuqya/pubhtml?widget=true&amp;headers=false"></iframe>




可编辑的嵌入-(Option#1)
此方案显示了OP的问题的解决方案。用户可以编辑其行的数据。有一个缺点-用户可以完全访问其工作表。他们可以使用链接到主表的行和列之外的行和列,可以添加表,但更糟的是,可以删除表。

这两篇宝贵的文章介绍了如何创建可编辑的嵌入: Google Docs: Embedding editable Google DocsHow to: Embed an editable Google Docs sheet

Codepen example

<iframe width="100%" height="400" src="https://docs.google.com/spreadsheets/d/1XqT5umvq2vzK7CEivVJXTJdKlBW07bP9nnMMWs2px_Y/edit?usp=sharing"></iframe>


有一些注意事项:


名为“ Fred”的用户表已为“ Share [d]”。在这种情况下,我选择“任何具有链接的人”,以便它在Codepen中起作用,但是在实践中,我将设置权限,以便只有指定人员才能编辑工作表。
母版表是挂锁的,这意味着它是可见的,但不可编辑。另一个选择是完全隐藏母版表,但我选择了其他方式,以便向所有者展示这些选项。
请注意,其他用户表(称为“ Joe”)不可见(因为尚未共享”)。
请注意,在用户工作表上编辑的所有内容(称为“ Fred”)都将立即在母版中更新(称为“ Coy_Summary”)
如上所述,用户可以删除其工作表或添加额外的工作表。但是,本文(和代码)“ Google Spreadsheet Script To Insert And Delete Sheets with Protection”显然非常有效。我还没有尝试过-我会把它留给其他人。


可编辑的嵌入-(Option#2)
这是我的建议如何运作的一个例子。每个用户(在这种情况下为“ Brian”)都有自己的文件(工作表),而主表则通过“ IMPORTRANGE”功能获取用户数据。另一个方面是,用户只限于两行(尽管没有什么限制对额外列的访问)。

请参阅 Google sheet

文档“ How to embed specific cells range when embedding a Google spreadsheet”是必读的。它详细说明了如何限制嵌入范围。辉煌! “ How to Share only Specific Sheet/Single Tab in Google Spreadsheet?”也很有价值。

Codepen example

<iframe width="250" height="75" src="https://docs.google.com/spreadsheets/d/e/2PACX-1vSzsA_yrb2uBCXywikOAbWrLnnEPYazevavza7PmtX9C6-xNw4p31gtCRBiCyxYkxVK7aMAWY1xZJ2o/pubhtml/sheet?headers=false&amp;gid=936292221&amp;range=A1:C2"></iframe>


顺便说一句,如果您查看Codepen Option#1中的主表,则可以看到实际的“ importrange”公式。

这是母版表B列中“项目#”的公式:

=importrange("https://docs.google.com/spreadsheets/d/1-HtjEawH7p45qKY5c0syIOnTF15endnG4L8wIIPEaAs/edit?usp=sharing", "Brian!b2:b2")

关于google-sheets - 仅嵌入一系列可编辑的Google电子表格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46059687/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com