我正在将ticks值转换为这样的日期:
Convert(datetime, (MachineGroups.TimeAdded - 599266080000000000)/864000000000);
使用这个我得到:
9/27/2009 10:50:27 PM
但我想要这种格式的日期:
October 1, 2009
我的样本滴答值是
633896886277130000
这样做的最佳方式是什么?
答案 0 :(得分:165)
可以使用特定的ticks值构造DateTime对象。确定滴答值后,您可以执行以下操作:
DateTime myDate = new DateTime(numberOfTicks);
String test = myDate.ToString("MMMM dd, yyyy");
答案 1 :(得分:45)
这样做要简单得多:
DateTime dt = new DateTime(633896886277130000);
哪个给出了
dt.ToString() ==> "9/27/2009 10:50:27 PM"
您可以使用dt.ToString(MyFormat)
以任何方式格式化此格式。有关格式字符串,请参阅this reference。 "MMMM dd, yyyy"
适用于您在问题中指定的内容。
不确定10月1日你到哪里。
答案 2 :(得分:5)
private void button1_Click(object sender, EventArgs e)
{
long myTicks = 633896886277130000;
DateTime dtime = new DateTime(myTicks);
MessageBox.Show(dtime.ToString("MMMM d, yyyy"));
}
给出
September 27, 2009
这就是你需要的吗?
我不知道这种格式在SQL查询中是如何使用的。
答案 3 :(得分:0)
到目前为止,答案已经帮助我提出了我的答案。我对UTC与当地时间保持警惕;刻度应始终为UTC IMO。
public class Time
{
public static void Timestamps()
{
OutputTimestamp();
Thread.Sleep(1000);
OutputTimestamp();
}
private static void OutputTimestamp()
{
var timestamp = DateTime.UtcNow.Ticks;
var localTicks = DateTime.Now.Ticks;
var localTime = new DateTime(timestamp, DateTimeKind.Utc).ToLocalTime();
Console.Out.WriteLine("Timestamp = {0}. Local ticks = {1}. Local time = {2}.", timestamp, localTicks, localTime);
}
}
输出:
Timestamp = 636988286338754530. Local ticks = 636988034338754530. Local time = 2019-07-15 4:03:53 PM.
Timestamp = 636988286348878736. Local ticks = 636988034348878736. Local time = 2019-07-15 4:03:54 PM.