如果字符串不为 null 或为空,则在字符串之间添加字符串



支持我有 4 个字符串,我想在它们之间添加一个 OR 运算符:

Dim s1="db = 45 AND frec = 500 "
Dim s2="db = 25 AND frec = 1 "
Dim s3="db = 5 AND frec = 2 "
Dim s4="db = 15 AND frec = 4 "

所以

Dim result = "db = 45 AND frec = 500 OR db = 25 AND frec = 1 OR db = 5 AND frec = 2 OR db = 15 AND frec = 4"

像连接字符串一样容易

Dim result= s1 & " OR " & s2 & " OR " & s3 & " OR " & s4

但是,通常,任何字符串都可以为空或为空所以如果我连接空字符串,我会得到

例如s2 = ""

Dim result = "db = 45 AND frec = 500 OR  OR db = 5 AND frec = 2 OR db = 15 AND frec = 4"

这是不正确的,我想替换像"OR OR"这样的字符串

 Dim result = result.Replace("OR OR", "")

有更好的方法吗? 一个快速的解决方案是对所有情况进行硬编码,但猜测这不太好

(我无法更改此设计,因为字符串用于其他几件事(

在 C# 中:

 string.Join(" OR ", new[] { stringA, stringB }
      .Where(s => !string.IsNullOrEmpty(s)));

请注意,这也适用于较大的数组。添加.ToArray()以防你使用的是 .NET <4.0

我只是想扔掉一些东西,以防您打算对数据库或类似的东西执行此操作。 简单地在子句之间加上"OR"不会返回您期望的结果。 您需要首先在条件周围加上括号,以保留现有逻辑。

最像你的意思是:

(db = 45 且 frec =

500( 或 (db = 25 且 frec = 1( 或 (....

只是要小心,否则你可能会对你得到的东西感到惊讶。 祝你好运!

最新更新