2013-03-19 79 views
0

我有这个列表,我用它来分隔成稍后用作输入中的命令的参数。以逗号分隔的列表中的分隔符和自由文本字段

问题是,其中一个字段是自由文本,可供用户编写。如何确保格式化自由文本或我使用不能被用户意外使用的分隔符?现在我使用逗号分隔命令,但我担心用户会写一个逗号并弄乱解决方案。

这里最好的做法是什么?

回答

1

您可以选择一个深奥/不能输入字符作为你的分隔符,或者你可以使用转义字符。

即:

command|parameter, string <- Esoteric character 

command,parameter\, string <- Escape character 

就个人而言,我会选择一个深奥的性格,因为你仍然可以使用简单的String.Split功能。您可以随时检查用户的输入,以确保它们没有包含您用作分隔符的字符的参数。

+0

深奥的字符是什么意思?似乎是一个很好的解决方案,如果我可以使用它来分割我的命令... – 2013-03-19 11:56:16

+0

一个不常见的字符,人们不可能输入 - 像管道符号,或者〜也许。你也可以使用两个字符,这是不太可能的。 – Richard 2013-03-19 16:20:04

+0

啊,谢谢,我的英文不够好,不能理解:) – 2013-03-20 07:25:19

0

The MIME standard for CSV files介绍了如何正确地构建,可能包含逗号的CSV文件:

  1. 将值附在双引号内
  2. 如果值内有双引号,则将其加倍

例如,假设你想建立一个CSV具有以下值文件:

Hello 
Well, does this work? 
I guess this "kinda" work 

那么结果将是:

"Hello","Well, does this work?","I guess this ""kinda"" work" 
0

我最终得到的解决方案看起来像这样,它使用三个深奥字符来最大限度地减少与用户输入混淆的风险。

return string.Format("true|~|eventEdit|~|{0}|~|{1}|~|{2}|~|{3}|~|{4}", variable,   variable, variable, variable, variable); 

string[] stringSeparators = new string[] { "|~|" }; 
string[] parameters = PlanningTypeIcon.CommandArgument.ToString().Split(stringSeparators, StringSplitOptions.None);