【问题标题】:How to escape % in String.Format?如何在 String.Format 中转义 %?
【发布时间】:2011-06-28 01:41:01
【问题描述】:

我在我的 strings.xml 文件中存储了一个 SQL 查询,我想使用 String.Format 在代码中构建最终字符串。 SELECT 语句使用了like,类似这样:

SELECT Field1, Field2 FROM mytable WHERE Field1 LIKE '%something%'

为了格式化我用 %1$s 替换 'something' 所以它变成:

SELECT Field1, Field2 FROM mytable WHERE Field1 LIKE \'%%1$s%\'

我用反斜杠转义单引号。但是我无法逃脱 % 符号。

如何在我的 strings.xml 文件中包含 like 语句?

【问题讨论】:

  • 别忘了正确地转义 %s。
  • 他们会注入到他们自己的数据库中,这里不用担心 ;)
  • 好吧,即使是你自己的数据库,也有可能不小心写出做坏事的查询。或者只是编写不编译的查询。准备查询是一个好习惯。
  • 虽然它比String.format() 慢,但你可以考虑改用MessageFormat()

标签: java android string syntax


【解决方案1】:

要逃脱%,您需要将其加倍:%%

【讨论】:

    【解决方案2】:

    要补充上述解决方案,请使用:

    str = str.replace("%", "%%");
    

    【讨论】:

    • 这将替换已经翻倍的 %。请阅读其他答案。
    • @Toilal 为什么有人会逃脱已经逃脱的东西?如果他愿意,为什么不实际去做呢?也许他打算有两个 % 符号,所以正确的转义形式是 '%%%%'
    【解决方案3】:

    这是一个更强大的正则表达式替换,它不会替换输入中已经加倍的 %%。

    str = str.replaceAll("(?:[^%]|\\A)%(?:[^%]|\\z)", "%%");
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-04-15
      相关资源
      最近更新 更多