31

DateTimeC# で時間を表示するために使用しています。時刻を作成するときに、誰もがどの日付部分を使用しますか?

たとえば、0 番目の月または 0 番目の日がないため、次は無効です。

// 4:37:58 PM
DateTime time = new DateTime(0, 0, 0, 16, 47, 58);

COM のゼロ デイトを使用しますか?

// 4:37:58 PM
DateTime time = new DateTime(1899, 12, 30, 16, 47, 58);

それとも SQL Server のものでしょうか?

//4:37:58 PM
DateTime time = new DateTime(1900, 1, 1, 16, 47, 58);

コードの日付部分を無視するので、それは恣意的だと​​思いますが、それでも使用できると便利です:

DateTime duration = time2 - time1;

答え

私はMinValueが好きだと思います

 DateTime time = DateTime.MinValue.Date.Add(new TimeSpan(16, 47, 58));

注:は使用できませんTimeSpan。これは時刻を保存しないためです。私がそれを知っている理由は、その内容を時間として表示する方法がないからです。

つまり、 time of dayではなく、span of timeTimeSpanを記録します。例:

TimeSpan t = new TimeSpan(16, 47, 58);
t.ToString();

時間::の形式で期間を返します。例:

16:47:58

時間ではなく:

4:47:58 PM    (United States)
04:47:58 nm   (South Africa)
4:47:58.MD    (Albania)
16:47:58      (Algeria)
04:47:58 م    (Bahrain)
PM 4:47:58    (Singapore)
下午 04:47:58  (Taiwan)
04:47:58 PM   (Belize)
4:47:58 p.m.  (New Zealand)
4:47:58 μμ    (Greece)
16.47.58      (Italy)
오후 4:47:58   (Korea)
04:47:58 ب.ظ  (Iran)
ਸ਼ਾਮ 04:47:58   (India)
04:47:58 p.m. (Argentina)
etc

つまり、タイムスパンと時間の間には違いがあります。TimeSpanまた、時間の範囲を時刻に変換するメカニズムが提供されていないことも理解してください。それには理由があります。

4

12 に答える 12

26

DateTime.MinValueはどうですか?

于 2008-12-16T20:40:35.800 に答える
8

時間構造が必要な人たちを助けましょう:

/// <summary>
/// Time structure
/// </summary>
public struct Time : IComparable
{
    private int minuteOfDay;
    public static Time Midnight = "0:00";
    private static int MIN_OF_DAY = 60 * 24;

    public Time(int minuteOfDay)
    {
        if (minuteOfDay >= (60 * 24) || minuteOfDay < 0)
            throw new ArgumentException("Must be in the range 0-1439", "minuteOfDay");
        this.minuteOfDay = minuteOfDay;
    }

    public Time(int hour, int minutes)
    {
        if (hour < 0 || hour > 23)
            throw new ArgumentException("Must be in the range 0-23", "hour");
        if (minutes < 0 || minutes > 59)
            throw new ArgumentException("Must be in the range 0-59", "minutes");

        minuteOfDay = (hour * 60) + minutes;
    }

    #region Operators
    public static implicit operator Time(string s)
    {
        var parts = s.Split(':');
        if (parts.Length != 2)
            throw new ArgumentException("Time must be specified on the form tt:mm");
        return new Time(int.Parse(parts[0]), int.Parse(parts[1]));
    }


    public static bool operator >(Time t1, Time t2)
    {
        return t1.MinuteOfDay > t2.MinuteOfDay;
    }
    public static bool operator <(Time t1, Time t2)
    {
        return t1.MinuteOfDay < t2.MinuteOfDay;
    }
    public static bool operator >=(Time t1, Time t2)
    {
        return t1.MinuteOfDay >= t2.MinuteOfDay;
    }
    public static bool operator <=(Time t1, Time t2)
    {
        return t1.MinuteOfDay <= t2.MinuteOfDay;
    }
    public static bool operator ==(Time t1, Time t2)
    {
        return t1.GetHashCode() == t2.GetHashCode();
    }
    public static bool operator !=(Time t1, Time t2)
    {
        return t1.GetHashCode() != t2.GetHashCode();
    }

    /// Time
    /// Minutes that remain to
    /// Time conferred minutes
    public static Time operator +(Time t, int min)
    {
        if (t.minuteOfDay + min < (24 * 60))
        {
            t.minuteOfDay += min;
            return t;
        }
        else
        {
            t.minuteOfDay = (t.minuteOfDay + min) % MIN_OF_DAY;
            return t;
        }
    }

    public static Time operator -(Time t, int min)
    {
        if (t.minuteOfDay - min > -1)
        {
            t.minuteOfDay -= min;
            return t;
        }
        else
        {
            t.minuteOfDay = MIN_OF_DAY + (t.minuteOfDay - min);
            return t;
        }
    }

    public static TimeSpan operator -(Time t1, Time t2)
    {
        return TimeSpan.FromMinutes(Time.Span(t2, t1));
    }
    #endregion


    public int Hour
    {
        get
        {
            return (int)(minuteOfDay / 60);
        }
    }
    public int Minutes
    {
        get
        {
            return minuteOfDay % 60;
        }
    }


    public int MinuteOfDay
    {
        get { return minuteOfDay; }
    }

    public Time AddHours(int hours)
    {
        return this + (hours * 60);
    }

    public int CompareTo(Time other)
    {
        return this.minuteOfDay.CompareTo(other.minuteOfDay);
    }

    #region Overrides
    public override int GetHashCode()
    {
        return minuteOfDay.GetHashCode();
    }

    public override string ToString()
    {
        return string.Format("{0}:{1:00}", Hour, Minutes);
    }
    #endregion

    /// 
    /// Safe enumerering - whatever interval applied max days 
    /// 
    /// Start time
    /// Spring in minutes
    /// 
    public static IEnumerable Range(Time start, int step)
    {
        return Range(start, start, step);
    }

    /// 
    /// Safe enumeration - whatever interval applied max days
    /// 
    public static IEnumerable Range(Time start, Time stop, int step)
    {
        int offset = start.MinuteOfDay;
        for (var i = 0; i < Time.Span(start, stop); i += step)
        {
            yield return Time.Midnight + (i + offset);
        }
    }

    /// 
    /// Calculates the number of minutes between t1 and t2
    /// 
    public static int Span(Time t1, Time t2)
    {
        if (t1 < t2) // same day
            return t2.MinuteOfDay - t1.MinuteOfDay;
        else // over midnight
            return MIN_OF_DAY - t1.MinuteOfDay + t2.MinuteOfDay;
    }
}
于 2009-05-18T23:07:49.260 に答える
7

TimeSpanは、最も確実に1日の時刻を保存できます。値は、基本的に時計を読み取るのと同じように、真夜中から経過した時間として扱う必要があります。

于 2008-12-16T20:41:08.280 に答える
6

個人的にTime structは、インスタンスを含み、DateTime同様のプロパティ、コンストラクターなどを持つカスタムを作成しますが、日/月/などは公開しません。含まれているインスタンスにすべてのパブリック アクセサーを渡すだけです。次に、エポックをprivate static readonly DateTimeフィールドとして単純に持つことができます。選択した値はすべてカスタム構造体にきちんと含まれているため、問題ありません。コードの残りの部分では、次のように簡単に記述できます。

var time = new Time(16, 47, 58);
于 2008-12-16T21:53:23.623 に答える
4

DateTime.TimeOfDayがTimeSpanを返すことを考えると、私はそれを使用します。

なぜTimeSpanを使用できないのですか?時刻が保存されていないというコメントがわかりません。

于 2008-12-16T20:40:51.150 に答える
3

どうですかDateTime.Now.TimeOfDay、そして使用しTimeSpanますか?

「それはその日の時間を保存しないからです。」TimeSpan-ええと、真夜中からの時間と考えるとそうです。

たとえば、「持続時間」は悲鳴を上げTimeSpanます。

于 2008-12-16T20:39:10.497 に答える
3

ローカル カルチャで書式設定された TimeSpan を表示するには、DateTime.Today のような日付に追加するだけです。このようなもの:

(DateTime.Today + timeSpan).ToString();

値は実際には日付を表していないため、表示する時が来るまで TimeSpan として保存することをお勧めします。

于 2008-12-16T21:32:17.987 に答える
1

私はお勧めDateTime.MinValue

于 2008-12-16T20:41:26.623 に答える
1

場合によっては、カスタム構造体でできることを提案できますか? Int32 バッキング値を持つことができます (1 日は 8,600 万ミリ秒です。これは Int32 に収まります)。

取得専用のプロパティが存在する可能性があります:

時 分 秒 ミリ秒

+、- などの演算子をオーバーロードすることもできます。IEquatable、IComparable などを実装します。== に等しいオーバーロード。ToString をオーバーロードしてオーバーライドします。

また、DateTime から作成したり、datetime に追加したりするメソッドをさらに提供することもできます。

于 2008-12-17T00:47:28.827 に答える
1

文字列リテラルを使用して新しい DateTime を作成するだけです。

時間の文字列リテラル:

DateTime t = new DateTime("01:00:30");

日付の文字列リテラル:

DateTime t = new DateTime("01/05/2008"); // english format
DateTime t = new DateTime("05.01.2008"); // german format

日付と時刻の値を持つ DateTime の場合:

DateTime t = new DateTime("01/05/2008T01:00:30");

ほとんどの場合、DateTime を作成するときに、実際に他の値に設定されていない場合は、DateTime.Now に設定します。DateTime を手動でインスタンス化する場合は、DateTimeKind が正しく設定されていることに注意する必要があります。そうしないと、驚きにつながる可能性があります。

于 2008-12-16T21:47:06.070 に答える
0

TimeSpanを使用し、TimeZoneに問題がある場合はUTCにします。

于 2008-12-16T23:10:34.793 に答える
0

受け入れられた回答と比較して大きな違いはありません。アイデアを実装するだけです。

public class TimeOfDay
{
    public DateTime time;
    public TimeOfDay(int Hour, int Minute, int Second)
    {
        time = DateTime.MinValue.Date.Add(new TimeSpan(Hour, Minute, Second));
    }
}
于 2014-03-31T03:25:29.000 に答える