如何将一个月份名称(字符串)解析为一个整数,以便在C#中进行比较?

时间:2008-11-03 14:33:08

标签: c# parsing integer compare

我需要能够比较数组中的一些月份名称。

如果有一些直接的方式会很好:

Month.toInt("January") > Month.toInt("May")

我的谷歌搜索似乎建议唯一的方法是编写自己的方法,但这似乎是一个普遍的问题,我认为它本来已经在.Net中实现过了,之前有人这样做了吗?

14 个答案:

答案 0 :(得分:164)

DateTime.ParseExact(monthName, "MMMM", CultureInfo.CurrentCulture ).Month

虽然为了您的目的,您可能最好只创建Dictionary<string, int>将月份名称映射到其值。

答案 1 :(得分:20)

你可以这样做:

Convert.ToDate(month + " 01, 1900").Month

答案 2 :(得分:19)

如果你使用了几个人建议的DateTime.ParseExact() - 方法,你应该仔细考虑当应用程序在非英语环境中运行时你想要发生什么!

在丹麦,ParseExact("Januar", ...)ParseExact("January", ...)哪个应该有效,哪个应该失败?

这将是CultureInfo.CurrentCultureCultureInfo.InvariantCulture之间的差异。

答案 3 :(得分:8)

您可以使用DateTime.Parse方法获取DateTime对象,然后检查其Month属性。做这样的事情:

int month = DateTime.Parse("1." + monthName + " 2008").Month;

诀窍是建立一个有效的日期来创建一个DateTime对象。

答案 4 :(得分:7)

您可以使用月份枚举:

public enum Month
{
    January,
    February,
    // (...)
    December,
}    

public Month ToInt(Month Input)
{
    return (int)Enum.Parse(typeof(Month), Input, true));
}

尽管如此,我并不是100%肯定enum.Parse()的语法。

答案 5 :(得分:7)

您不必创建DateTime实例来执行此操作。就这么简单:

public static class Month
{
    public static int ToInt(this string month)
    {
        return Array.IndexOf(
            CultureInfo.CurrentCulture.DateTimeFormat.MonthNames,
            month.ToLower(CultureInfo.CurrentCulture))
            + 1;
    }
}

我正在运行da-DK文化,所以这个单元测试通过了:

[Theory]
[InlineData("Januar", 1)]
[InlineData("Februar", 2)]
[InlineData("Marts", 3)]
[InlineData("April", 4)]
[InlineData("Maj", 5)]
[InlineData("Juni", 6)]
[InlineData("Juli", 7)]
[InlineData("August", 8)]
[InlineData("September", 9)]
[InlineData("Oktober", 10)]
[InlineData("November", 11)]
[InlineData("December", 12)]
public void Test(string monthName, int expected)
{
    var actual = monthName.ToInt();
    Assert.Equal(expected, actual);
}

我会把它作为练习留给读者创建一个重载,你可以传入一个显式的CultureInfo。

答案 6 :(得分:7)

一个简单的解决方案是创建一个包含名称和值的词典。然后使用Contains(),您可以找到正确的值。

Dictionary<string, string> months = new Dictionary<string, string>()
{
                { "january", "01"},
                { "february", "02"},
                { "march", "03"},
                { "april", "04"},
                { "may", "05"},
                { "june", "06"},
                { "july", "07"},
                { "august", "08"},
                { "september", "09"},
                { "october", "10"},
                { "november", "11"},
                { "december", "12"},
};
foreach (var month in months)
{
    if (StringThatContainsMonth.ToLower().Contains(month.Key))
    {
        string thisMonth = month.Value;
    }
}

答案 7 :(得分:2)

在提出问题七年后回答这个问题,可以使用内置方法进行比较:

Month.toInt("January") > Month.toInt("May")

变为

Array.FindIndex( CultureInfo.CurrentCulture.DateTimeFormat.MonthNames,
                 t => t.Equals("January", StringComparison.CurrentCultureIgnoreCase)) >
Array.FindIndex( CultureInfo.CurrentCulture.DateTimeFormat.MonthNames,
                 t => t.Equals("May", StringComparison.CurrentCultureIgnoreCase))

为简单起见,可以将其重构为扩展方法。以下是LINQPad示例(因此Dump()方法调用):

void Main()
{
    ("January".GetMonthIndex() > "May".GetMonthIndex()).Dump();
    ("January".GetMonthIndex() == "january".GetMonthIndex()).Dump();
    ("January".GetMonthIndex() < "May".GetMonthIndex()).Dump();
}

public static class Extension {
    public static int GetMonthIndex(this string month) {
        return Array.FindIndex( CultureInfo.CurrentCulture.DateTimeFormat.MonthNames,
                         t => t.Equals(month, StringComparison.CurrentCultureIgnoreCase));
    }
}

输出:

False
True
True

答案 8 :(得分:1)

如果您使用的是c#3.0(或更高版本),则可以使用扩展器

答案 9 :(得分:1)

我将其翻译成西班牙语版本的C#代码,问候:

public string ObtenerNumeroMes(string NombreMes){

       string NumeroMes;   

       switch(NombreMes) {

        case ("ENERO") :
            NumeroMes = "01";
            return NumeroMes;

        case ("FEBRERO") :
            NumeroMes = "02";
            return NumeroMes;

        case ("MARZO") :
            NumeroMes = "03";
            return NumeroMes;

        case ("ABRIL") :
            NumeroMes = "04";
            return NumeroMes;

        case ("MAYO") :
            NumeroMes = "05";
            return NumeroMes;

        case ("JUNIO") :
            NumeroMes = "06";
            return NumeroMes;

        case ("JULIO") :
            NumeroMes = "07";
            return NumeroMes;

        case ("AGOSTO") :
            NumeroMes = "08";
            return NumeroMes;

        case ("SEPTIEMBRE") :
            NumeroMes = "09";
            return NumeroMes;

        case ("OCTUBRE") :
            NumeroMes = "10";
            return NumeroMes;

        case ("NOVIEMBRE") :
            NumeroMes = "11";
            return NumeroMes;

        case ("DICIEMBRE") :
            NumeroMes = "12";
            return NumeroMes;

            default:
            Console.WriteLine("Error");
            return "ERROR";

        }

   }

答案 10 :(得分:0)

Public Function returnMonthNumber(ByVal monthName As String) As Integer
    Select Case monthName.ToLower
        Case Is = "january"
            Return 1
        Case Is = "february"
            Return 2
        Case Is = "march"
            Return 3
        Case Is = "april"
            Return 4
        Case Is = "may"
            Return 5
        Case Is = "june"
            Return 6
        Case Is = "july"
            Return 7
        Case Is = "august"
            Return 8
        Case Is = "september"
            Return 9
        Case Is = "october"
            Return 10
        Case Is = "november"
            Return 11
        Case Is = "december"
            Return 12
        Case Else
            Return 0
    End Select
End Function

警告代码属于Beta版本。

答案 11 :(得分:0)

我所做的是使用SimpleDateFormat创建格式字符串,并将文本解析为日期,然后从中检索月份。代码如下:

int year = 2012 \\or any other year
String monthName = "January" \\or any other month
SimpleDateFormat format = new SimpleDateFormat("dd-MMM-yyyy");
int monthNumber = format.parse("01-" + monthName + "-" + year).getMonth();

答案 12 :(得分:0)

此代码可帮助您...

using System.Globalization;

....

string FullMonthName = CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(DateTime.UtcNow.Month);

GetMonthName方法-返回字符串...

如果要以整数形式表示月份,则只需使用-

DateTime dt= DateTime.UtcNow;
int month= dt.Month;

希望对您有帮助!

谢谢!

答案 13 :(得分:0)

int selectedValue = 0;
            switch (curentMonth)
            {
                case "January":
                    selectedValue = 1;
                    break;
                case "February":
                    selectedValue = 2;
                    break;
            }
            if (selectedValue != 0)
            {
               /* var list= db.model_name.Where(x => x.column== selectedValue);
                return list; */
            }
            return Ok(selectedValue);