1. 程式人生 > >c#日期時間的操作的函式總結

c#日期時間的操作的函式總結

當前日期時間的獲取:

 DateTime datetime1=DateTime.Now;

日期時間的運算:

string str1=(datetime1.AddYears(1)).ToString(); //加年份

string str1=(datetime1.AddMonths(1)).ToString();//加月份

string str1=(datetime1.AddDays(1)).ToString();//加日期

string str1=(datetime1.AddHours(1)).ToString();//加小時

string str1=(datetime1.AddMinutes(1)).ToString();//加分

string str1=(datetime1.AddSeconds(1)).ToString();//加秒

string str1=(datetime1.AddMilliseconds(1)).ToString();//加毫秒 
long long1=System.DateTime.DaysInMonth(2005,2); //返回某年某月有幾天

string str1=datetime1.DayOfWeek.ToString("D"); //將星期轉換成數字字元 星期日為0

TimeSpan subtime=datetime1.Subtract(datetime2); //獲得datetime1和datetime2之間的間隔,具體時間可以從subtime中分離出來。

具體時間的分離:

  long long1=datetime1.Year;//取得年份 
  long long1=datetime1.Month;//取得月份 
  long long1=datetime1.Day;//取得日期 
  long long1=datetime1.Hour;//取得小時 
  long long1=datetime1.Minute;//取得分 
  long long1=datetime1.Second;//取得秒 
  long long1=datetime1.Millisecond;//取得毫秒

下面列出一些Asp.net中具體的日期格式化用法:


============================================
1.繫結時格式化日期方法: 

2.資料控制元件如DataGrid/DataList等的件格式化日期方法: 
e.Item.Cell[0].Text = Convert.ToDateTime(e.Item.Cell[0].Text).ToShortDateString();

3.用String類轉換日期顯示格式: 
String.Format( "yyyy-MM-dd ",yourDateTime);

4.用Convert方法轉換日期顯示格式: 
Convert.ToDateTime("2005-8-23").ToString

("yyMMdd",System.Globalization.DateTimeFormatInfo.InvariantInfo); //支援繁體資料庫

5.直接用ToString方法轉換日期顯示格式: 
DateTime.Now.ToString("yyyyMMddhhmmss"); 
DateTime.Now.ToString("yyyy/MM/dd hh:mm:ss")

6.只顯示年月 
DataBinder.Eval(Container.DataItem,"starttime","{0:yyyy-M}")

7.顯示時間所有部分,包括:年月日時分秒 

DataFormatString="{0:yyyy-MM-dd HH24:mm:ss}">

1.9 取中文日期顯示——年月日時分 
string strY=currentTime.ToString("f"); //不顯示秒 
 
1.10 取中文日期顯示_年月 
string strYM=currentTime.ToString("y"); 
 
1.11 取中文日期顯示_月日 
string strMD=currentTime.ToString("m"); 
 
1.12 取中文年月日 
string strYMD=currentTime.ToString("D"); 
 
1.13 取當前時分,格式為:14:24 
string strT=currentTime.ToString("t"); 
 
1.14 取當前時間,格式為:2003-09-23T14:46:48 
string strT=currentTime.ToString("s"); 
 
1.15 取當前時間,格式為:2003-09-23 14:48:30Z 
string strT=currentTime.ToString("u"); 
 
1.16 取當前時間,格式為:2003-09-23 14:48 
string strT=currentTime.ToString("g"); 
 
1.17 取當前時間,格式為:Tue, 23 Sep 2003 14:52:40 GMT 
string strT=currentTime.ToString("r"); 
 
1.18獲得當前時間 n 天后的日期時間 
DateTime newDay = DateTime.Now.AddDays(100);

----

DateTime dt = DateTime.Now;
Label1.Text = dt.ToString();//2005-11-5 13:21:25
Label2.Text = dt.ToFileTime().ToString();//127756416859912816
Label3.Text = dt.ToFileTimeUtc().ToString();//127756704859912816
Label4.Text = dt.ToLocalTime().ToString();//2005-11-5 21:21:25
Label5.Text = dt.ToLongDateString().ToString();//2005年11月5日
Label6.Text = dt.ToLongTimeString().ToString();//13:21:25
Label7.Text = dt.ToOADate().ToString();//38661.5565508218
Label8.Text = dt.ToShortDateString().ToString();//2005-11-5
Label9.Text = dt.ToShortTimeString().ToString();//13:21
Label10.Text = dt.ToUniversalTime().ToString();//2005-11-5 5:21:25

Label1.Text = dt.Year.ToString();//2005
Label2.Text = dt.Date.ToString();//2005-11-5 0:00:00
Label3.Text = dt.DayOfWeek.ToString();//Saturday
Label4.Text = dt.DayOfYear.ToString();//309
Label5.Text = dt.Hour.ToString();//13
Label6.Text = dt.Millisecond.ToString();//441
Label7.Text = dt.Minute.ToString();//30
Label8.Text = dt.Month.ToString();//11
Label9.Text = dt.Second.ToString();//28
Label10.Text = dt.Ticks.ToString();//632667942284412864
Label11.Text = dt.TimeOfDay.ToString();//13:30:28.4412864

Label1.Text = dt.ToString();//2005-11-5 13:47:04
Label2.Text = dt.AddYears(1).ToString();//2006-11-5 13:47:04
Label3.Text = dt.AddDays(1.1).ToString();//2005-11-6 16:11:04
Label4.Text = dt.AddHours(1.1).ToString();//2005-11-5 14:53:04
Label5.Text = dt.AddMilliseconds(1.1).ToString();//2005-11-5 13:47:04
Label6.Text = dt.AddMonths(1).ToString();//2005-12-5 13:47:04
Label7.Text = dt.AddSeconds(1.1).ToString();//2005-11-5 13:47:05
Label8.Text = dt.AddMinutes(1.1).ToString();//2005-11-5 13:48:10
Label9.Text = dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
Label10.Text = dt.CompareTo(dt).ToString();//0
Label11.Text = dt.Add(?).ToString();//問號為一個時間段

Label1.Text = dt.Equals("2005-11-6 16:11:04").ToString();//False
Label2.Text = dt.Equals(dt).ToString();//True
Label3.Text = dt.GetHashCode().ToString();//1474088234
Label4.Text = dt.GetType().ToString();//System.DateTime
Label5.Text = dt.GetTypeCode().ToString();//DateTime

Label1.Text = dt.GetDateTimeFormats('s')[0].ToString();//2005-11-05T14:06:25
Label2.Text = dt.GetDateTimeFormats('t')[0].ToString();//14:06
Label3.Text = dt.GetDateTimeFormats('y')[0].ToString();//2005年11月
Label4.Text = dt.GetDateTimeFormats('D')[0].ToString();//2005年11月5日
Label5.Text = dt.GetDateTimeFormats('D')[1].ToString();//2005 11 05
Label6.Text = dt.GetDateTimeFormats('D')[2].ToString();//星期六 2005 11 05
Label7.Text = dt.GetDateTimeFormats('D')[3].ToString();//星期六 2005年11月5日
Label8.Text = dt.GetDateTimeFormats('M')[0].ToString();//11月5日
Label9.Text = dt.GetDateTimeFormats('f')[0].ToString();//2005年11月5日 14:06
Label10.Text = dt.GetDateTimeFormats('g')[0].ToString();//2005-11-5 14:06
Label11.Text = dt.GetDateTimeFormats('r')[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT

Label1.Text = string.Format("{0:d}",dt);//2005-11-5
Label2.Text = string.Format("{0:D}",dt);//2005年11月5日
Label3.Text = string.Format("{0:f}",dt);//2005年11月5日 14:23
Label4.Text = string.Format("{0:F}",dt);//2005年11月5日 14:23:23
Label5.Text = string.Format("{0:g}",dt);//2005-11-5 14:23
Label6.Text = string.Format("{0:G}",dt);//2005-11-5 14:23:23
Label7.Text = string.Format("{0:M}",dt);//11月5日
Label8.Text = string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
Label9.Text = string.Format("{0:s}",dt);//2005-11-05T14:23:23
Label10.Text = string.Format("{0:t}",dt);//14:23
Label11.Text = string.Format("{0:T}",dt);//14:23:23
Label12.Text = string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
Label13.Text = string.Format("{0:U}",dt);//2005年11月5日 6:23:23
Label14.Text = string.Format("{0:Y}",dt);//2005年11月
Label15.Text = string.Format("{0}",dt);//2005-11-5 14:23:23 
Label16.Text = string.Format("{0:yyyyMMddHHmmssffff}",dt);//2005-11-5 13:30:28.4412864

C#比較兩時間大小
1、比較時間大小的實驗

string st1="12:13";

string st2="14:14";

DateTime dt1=Convert.ToDateTime(st1);

DateTime dt2=Convert.ToDateTime(st2);

DateTime dt3=DateTime.Now;

if(DateTime.Compare(dt1,dt2)>0)

msg.Text=st1+">"+st2;

else

msg.Text=st1+"<"+st2;

msg.Text+="\r\n"+dt1.ToString();

if(DateTime.Compare(dt1,dt3)>0)

msg.Text+="\r\n"+st1+">"+dt3.ToString();

else

msg.Text+="\r\n"+st1+"<"+dt3.ToString();


2、計算兩個時間差值的函式,返回時間差的絕對值:

private string DateDiff(DateTime DateTime1,DateTime DateTime2)

{

string dateDiff=null;

try

{

TimeSpan ts1=new TimeSpan(DateTime1.Ticks);

TimeSpan ts2=new TimeSpan(DateTime2.Ticks);

TimeSpan ts=ts1.Subtract(ts2).Duration();

dateDiff=ts.Days.ToString()+"天" +ts.Hours.ToString()+"小時" +ts.Minutes.ToString()+"分鐘" +ts.Seconds.ToString()+"秒";

}

catch

{
}

return dateDiff;

}
3、實現計算DateTime1-36天=DateTime2的功能
TimeSpan ts=new TimeSpan(40,0,0,0);

DateTime dt2=DateTime.Now.Subtract(ts);

msg.Text=DateTime.Now.ToString()+"-"+ts.Days.ToString()+"天\r\n"; msg.Text+=dt2.ToString();

相關推薦

C語言檔案操作函式總結——超詳細

版權宣告 本文原創作者:谷哥的小弟 作者部落格地址:http://blog.csdn.net/lfdfhl 檔案與流 在C語言中有三種標準流: stdin(standard input stream)標準輸入流。在大多數環境中為從鍵盤輸入;scanf( )和getchar( )

MySQL 日期/時間 操作函式(2.1)

一、MySQL 獲得當前日期時間 函式 1.1 獲得當前日期+時間 (date + time)函式:now() 同時獲取當前的年月日和時分秒 2. 獲得當前日期(date) 函式:curdate() mysql> select curdate(); +-------

C# 日期時間處理函式

# region 日期時間處理邏輯 // 將n轉化為2位符號數, 0-99 轉化為00-99 public static string TwoChar(int n) { return (n < 10 ? "0" : "") + n; } // 獲取Date

C語言字串操作函式總結

Part 1: Copying 1、函式名: strcpy 用法: char * strcpy ( char * destination, const char * source ); 功能: 串拷貝(

c#日期時間操作函式總結

當前日期時間的獲取:  DateTime datetime1=DateTime.Now; 日期時間的運算: string str1=(datetime1.AddYears(1)).ToString(); //加年份 string str1=(datetime1.AddMonths(1)).ToString(

c#日期時間總結

一、一般時間(常用的為黃色) DateTime dt = DateTime.Now; Console.WriteLine(dt.Date); //獲取日期 Console.WriteLine(dt.TimeOfDay); //獲取時間到毫秒:13:08:44.5278155 Console.WriteLin

C語言常用字串操作函式總結

函式名: strcpy 功 能: 將引數src字串拷貝至引數dest所指的地址 用 法: char *strcpy(char *dest, const char *src); 返回值: 返回引數de

mysql日期時間類型總結

days 5-0 ted 當前 可能 數據 oca uart mode MySQL 日期類型:日期格式、所占存儲空間、日期範圍 比較。 日期類型 存儲空間 日期格式 日期範圍 ------------ -----

c/c++日期時間處理與字符串string轉換

輸入輸出 一個數 代碼 string轉換 計算 字符 span 日期 時間轉化 在c/c++實際問題的編程中,我們經常會用到日期與時間的格式,在算法運行中,通常將時間轉化為int來進行計算,而處理輸入輸出的時候,日期時間的格式卻是五花八門,以各種標點空格相連或者不加標點。

MySQL 日期時間相關函式

第一部分:時間差函式  timestampdiff、datediff、timediff   一、時間差函式:timestampdiff   語法:timestampdiff(interval, datetime1,datetime2)   結果:返回(時間2-時間1)的時

js日期時間格式化函式

// author: meizz // 對Date的擴充套件,將 Date 轉化為指定格式的String // 月(M)、日(d)、小時(h)、分(m)、秒(s)、季度(q) 可以用 1-2 個佔位符, // 年(y)可以用 1-4 個佔位符,毫秒(S)只能用 1 個佔位符(是 1-3

c語言檔案操作函式講解

c語言檔案操作 什麼是檔案 磁碟上的檔案是檔案。包含程式檔案和資料檔案。 程式檔案:包括.c檔案,和可執行檔案(exe.檔案)。 資料檔案:程式從檔案中讀取,或者輸出檔案,比如存放資料的txt檔案。 檔名 檔名包含檔名+檔案主幹+檔案字尾。 檔案型別 檔案型別有文字檔

DB2日期時間處理函式

  使用 days 字元型的日期:2012-01-01,2012-01-11 values days(date('2012-01-11')) - days(date('2012-01-01')) --獲取當前日期: select current date from sysibm.sys

postgresql常見數值,字元,日期型別常見函式總結

一.字元函式 函式 描述 例子 char_length(string) 獲取字串中字元的個數 test=> select char_length('abc123蘇

c】檔案操作函式:fprintf,fread,fwrite,fseek,ftell,fopen,fclose,fflush以及獲取檔案長度示例

Date: 2018.9.20 1、參考 2、 fprintf 3、fread 作用:從一個檔案流中讀取資料。 Read block of data from stream Reads an ar

JS檢測日期時間格式函式

 利用日期函式配合正則表示式來檢測日期時間格式,: var checkTime = function (time) { var timeFormat = /^(\d{1,4})(-|\/)(\

C++刪除元素的函式總結

在C++中,刪除物件元素的方法可以用remove函式、erase函式、resize函式等。 1、remove函式 remove函式在STL中的原始碼如下: template <class In

C語言檔案操作函式大全

clearerr(清除檔案流的錯誤旗標) 相關函式 feof表頭檔案 #include<stdio.h> 定義函式 void clearerr(FILE * stream); 函式說明 clearerr()清除引數stream指定的檔案流所使用的錯誤旗標。返回值 fclose(關閉檔案) 相關函

C/C++毫秒時間函式

下面是產生毫秒時間戳的程式碼和測試案例 #include <stdio.h> #include <sys/timeb.h> #include <sys/types.h> long long getSystemTime()

C語言字串操作函式

C語言中(部分)字串操作函式簡介 strlen(p); // 計算指定的字串p的長度,不包括結束字元'\0' strcpy(p, p1); // 複製字串  strncpy(p, p1, n); // 複製指定長度字串  strcat(p, p1);