用于分隔值的字符串操作

本文关键字:字符串 操作 分隔 用于 | 更新日期: 2023-09-27 18:33:13

我有一个格式MASTER CARD 01/01/2012的字符串,我需要单独抓取日期部分。

有时可能是VISA 01/01/2012,我尝试按空格拆分,但是当有两个空格时卡住了,就像MASTER CARD 01/01/2012一样。

任何帮助将不胜感激;

string date = e.Brick.Text;
string[] dates = date.Split(' ');

用于分隔值的字符串操作

字符串的外观,您将在数组中的最后一个元素中获取日期。

//dates[dates.Length-1] should have date
    string date = "MASTER CARD 01/01/2012";
    string[] dates = date.Split(' ');
    Console.WriteLine(dates[dates.Length - 1]);

一个正确的解决方案应该是根据日期时间检查每个项目,即下一行的内容

DateTime tempDs = new DateTime();
            foreach (string str in dates)
            {
                if (DateTime.TryParse(str, out tempDs))
                {
                    Console.WriteLine("Found Date");
                }
            }

假设各种卡片的所有日期都具有相似的格式,正则表达式可能是一个可行的替代方案。

using System.Text.RegularExpressions;

Match mDate = Regex.Match(e.Brick.Text, @"'b(?<date>(?:'d{1,2}[''/-]){2}'d{4})'b", RegexOptions.Compiled);
if (mDate.Success)
{
    MessageBox.Show(string.Format("Date: {0}", mDate.Groups["date"].Value));
}

按空格拆分并使用 DateTime.TryParse 方法分析日期。 对于 VISA、MASTER 和 CARD,该方法应失败;但它将成功用于字符串的日期部分。

您可以使用您的代码。

如果日期总是在字符串的末尾,你可以做类似的事情

year = dates[dates.Length-1]

依此类推,表示月和日

这是另一种选择:

string date = e.Brick.Text.Substring(e.Brick.Text.LastIndexOf(' ')+1);

这应该可以解决问题。

public string ExtractDateTimeString(string s){
    return s.Split(' ').Where(x => 
            {
                DateTime o;
                return DateTime.TryParse(x, out o);
            }).FirstOrDefault();
}

或者另一种方式:

        string text = "MASTER CARD 4.5.2012";
        string[] split = text.Split(' ');
        string mc = "";
        string date = ""; //when you get this value, you can easily convert to date if you need it
        foreach (string str in split)
        {
            if (char.IsNumber(str[0]))
            {
                date = str;
                mc = mc.Remove(mc.Length - 1, 1);
            }
            else
                mc += str + " ";
        }