开发者

How to escape % in String.Format?

开发者 https://www.devze.com 2023-02-10 22:42 出处:网络
I am storing a SQL query in my strings.xml file and I want to use String.Format to buil开发者_如何转开发d the final string in code.The SELECT statement uses a like, something like this:

I am storing a SQL query in my strings.xml file and I want to use String.Format to buil开发者_如何转开发d the final string in code. The SELECT statement uses a like, something like this:

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

In order to format that I replace 'something' with %1$s so it becomes:

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

I escape the single quotes with the backslash. However I am not able to escape the % sign.

How can I include a like statement in my strings.xml file?


To escape %, you will need to double it up: %%.


To complement the previous stated solution, use:

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


This is a stronger regex replace that won't replace %% that are already doubled in the input.

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

精彩评论

暂无评论...
验证码 换一张
取 消