71

多元文化编程的有趣部分之一是数字格式。

  • 美国人使用 10,000.50
  • 德国人使用 10.000,50
  • 法国使用 10 000,50

我的第一种方法是获取字符串,将其向后解析,直到遇到分隔符并将其用作小数分隔符。这样做有一个明显的缺陷:10.000 会被解释为 10。

另一种方法:如果字符串包含 2 个不同的非数字字符,则使用最后一个作为小数分隔符并丢弃其他字符。如果我只有一个,请检查它是否多次出现,如果出现则丢弃它。如果它只出现一次,请检查它后面是否有 3 位数字。如果是,则丢弃它,否则,将其用作小数分隔符。

显而易见的“最佳解决方案”是检测用户的文化或浏览器,但如果您有一个使用 en-US Windows/浏览器的法国人,这将不起作用。

Double.(Try)Parse().net 框架是否包含一些比尝试自动检测数字格式更好的神秘黑魔法浮点解析器?

4

4 回答 4

31

我认为在这种情况下你能做的最好的事情就是听取他们的意见,然后向他们展示你认为他们的意思。如果他们不同意,请向他们展示您期望的格式并让他们再次输入。

于 2008-08-01T23:17:53.657 回答
27

我不知道问题的 ASP.NET 方面,但 .NET 有一个非常强大的类:System.Globalization.CultureInfo。您可以使用以下代码解析包含双精度值的字符串:

double d = double.Parse("100.20", CultureInfo.CurrentCulture);
//  -- OR --
double d = double.Parse("100.20", CultureInfo.CurrentUICulture);

如果 ASP.NET 以某种方式(即使用 HTTP 请求标头)将当前用户的 CultureInfo 传递给 CultureInfo.CurrentCulture 或 CultureInfo.CurrentUICulture,这些都可以正常工作。

于 2008-08-01T20:02:08.357 回答
12

你不可能取悦所有人。如果我输入十作为 10.000,而有人输入一万作为 10.000,如果不了解输入的文化,您将无法处理。以某种方式检测文化(浏览器、系统设置 - 用例是什么?ASP?内部应用程序,还是向世界开放?),或提供预期格式的示例,并尽可能使用最宽松的解析器。大概是这样的:

double d = Double.Parse("5,000.00", NumberStyles.Any, CultureInfo.InvariantCulture);
于 2008-08-01T20:05:12.750 回答
10

法语和英语中的 12.345 之间的差异是 1000 倍。如果您提供 max < 1000*min 的预期范围,您可以轻松猜到。

以一个人(包括婴儿和儿童)的身高为例,单位为毫米。

通过使用 200-3000 的范围,1.800 或 1,800 的输入可以明确地解释为 1 米和 80 厘米,而 912.300 或 912,300 的输入可以明确地解释为 91 厘米和 2.3 毫米。

于 2008-08-02T12:28:12.517 回答