我想知道如何处理这样的查询。假设电子表格的单元格 A2 中包含以下文本:
Case Bakers' Flats 12" White Flour Tortillas 10/12ct
并需要将以下公式代入B2:
=QUERY(importrange("KEY", "DATA!A1:Z1000"), "select Col24 where (Col1 = '"&A2&"')")
它会产生一个错误。
我的问题是:当我使用的字符串包含任何种类的引号和撇号时,有什么方法可以避免查询失败?
简短回答
- 要转义单引号/撇号,请在双引号 (
"
).
- 要转义双引号,请应用双替换,首先删除双引号,然后再次添加它们。
解释
Google Sheets QUERY 内置函数通过内部添加自动转义某些字符\
在单引号之前,但当用作条件源的单元格值包含双引号时,它不起作用。作为一种解决方法,建议使用双重替换。
单引号/撇号示例
下表代表电子表格范围,其中包含
- A 列:数据源
- 单元格 B1:条件表达式中使用的数据值
- 单元格 C1:以下公式
=QUERY(A:A,"SELECT * WHERE A = """&B1&""" ")
+---+---------+-----+-----+
| | A | B | C |
+---+---------+-----+-----+
| 1 | I'm | I'm | I'm |
| 2 | You're | | |
| 3 | It's | | |
| 4 | I am | | |
| 5 | You are | | |
| 6 | It is | | |
+---+---------+-----+-----+
单引号/撇号和双引号的示例
=SUBSTITUTE(
QUERY(
SUBSTITUTE(A:A,"""","''"),
"SELECT * WHERE Col1 = """&SUBSTITUTE;(B1,"""","''")&""""
),
"''",""""
)
请注意,它没有使用字母 A 作为数据源列的标识符,而是使用 Col1。
参考
https://developers.google.com/chart/interactive/docs/querylanguage https://developers.google.com/chart/interactive/docs/querylanguage
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)