将UNIX时间转换为普通日期&时间C#

时间:2012-04-08 16:31:57

标签: c# visual-studio-2010 datagridview unix-timestamp

我在SQLite3数据库中填充程序中的数据网格视图,该数据库包含使用下面代码的日期列

此日期列存储在Unix时间内,我希望将其显示为正常日期

当我将数据库读入数据网格视图时,有没有办法可以做到这一点?

SQLiteConnectionStringBuilder csb = new SQLiteConnectionStringBuilder();
csb.DataSource = Path.Combine(connectionPath, "sms.db");

SQLiteConnection connection = new SQLiteConnection(csb.ConnectionString);
connection.Open();

// SQL query to read the data fromt he database
SQLiteCommand command = connection.CreateCommand();
//Read Everything
string query = "SELECT * FROM message";

command.CommandText = query;

SQLiteDataAdapter dataAdaptor = new SQLiteDataAdapter(command);
DataSet dataset = new DataSet();
dataAdaptor.Fill(dataset, "Messages");
// Get the table from the data set
DataTable datatable = dataset.Tables["Messages"];

dataGridSMS.DataSource = datatable;

2 个答案:

答案 0 :(得分:3)

// This is an example of a UNIX timestamp for the date/time
double timestamp = 1116641532;

// First make a System.DateTime equivalent to the UNIX Epoch.
System.DateTime dateTime = new System.DateTime(1970, 1, 1, 0, 0, 0, 0);

// Add the number of seconds in UNIX timestamp to be converted.
dateTime = dateTime.AddSeconds(timestamp).ToLocalTime();

答案 1 :(得分:0)

使用DataGridView.CellFormatting Event

private void dataGridSMS_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
    {
        if (this.dataGridSMS.Columns[e.ColumnIndex].Name == "dateColumn")
        {
            if (e.Value != null)
            {
                try
                {
                    // Formatting
                    double timestamp = Convert.ToDouble(e.Value); // if e.Value is string you must parse
                    System.DateTime dateTime = new System.DateTime(1970, 1, 1, 0, 0, 0, 0);
                    dateTime = dateTime.AddSeconds(timestamp).ToLocalTime();
                    e.Value = dateTime.ToString();
                    e.FormattingApplied = true;
                }
                catch (Exception)
                {
                    e.FormattingApplied = false;
                }
            }
        }
    }