簡體   English   中英

C#對逗號分隔的數字進行排序

[英]C# sort string of comma separated numbers

在C#中,您認為最快的方法是什么? 代碼最終將成為SQL Server CLR C#用戶定義函數的一部分,但我認為這對於這個問題並不重要。

INPUT:  "1,3,2,5,4"
OUTPUT: "1,2,3,4,5"

必須通過將數字作為整數進行比較來完成排序,而不是將字符串或字符進行比較。

我目前有以下內容,但它是基於字符串排序,而不是整數。 我可以介紹一個自定義的比較器但是我會問這個問題,看看其他人在我這樣做之前是否有任何想法。

[Microsoft.SqlServer.Server.SqlFunction]
public static SqlString udfSortDimensionValueIDString(SqlString DimensionValueIDs)
{
    string[] values = ((string)DimensionValueIDs).Split(',');
    Array.Sort(values);
    return String.Join(",", values);
}

如果重要,請使用.NET 3.5。

你可以使用Linq

  using System.Linq; // no include required, just uses the namespace

  ...

  String Input = "1,3,2,5,4";

  String Output = String.Join(",", Input
    .Split(',')
    .Select(x => int.Parse(x))
    .OrderBy(x => x));
string s = "1,3,2,5,4";
string ordered = String.Join(",", s.Split(',').Select(c => Convert.ToInt32(c)).OrderBy(i=>i));

您可以在逗號上拆分字符串,並使用Convert庫將每個字符串轉換為數字。 http://msdn.microsoft.com/en-us/library/bb397679.aspx

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM