Python の datetime モジュールの概要 (例付き)
この記事では、Python の datetime モジュールの紹介 (例を示します) を紹介します。これには特定の参考値があります。必要な友人は参照できます。お役に立てば幸いです。
Python には、カレンダー、時刻、日付時刻など、日付と時刻を操作するための複数の組み込みモジュールが用意されています。 time モジュールによって提供されるインターフェイスは、基本的に C 標準ライブラリ time.h と一致しています。 time モジュールと比較して、datetime モジュールのインターフェイスはより直感的で呼び出しやすくなっています。
モジュールは 2 つの定数を定義します:
datetime.MINYEAR
datetime.MAXYEAR
これら 2 つの定数は、それぞれ、datetime が表現できる最小年と最大年を表します。このうち、MINYEAR = 1、MAXYEAR = 9999 となります。
datetime このモジュールは次のクラスを定義します。
datetime.date: 日付を表すクラス。一般的に使用される属性には、年、月、日が含まれます。
datetime.time: 時間を表すクラス。一般的に使用される属性には、時、分、秒、マイクロ秒が含まれます。
datetime.datetime: 日付と時刻を表します。
datetime.timedelta: 時間間隔、つまり 2 つの時点間の長さを示します。
datetime.tzinfo: タイムゾーンに関連する関連情報。
注: 上記のオブジェクトの種類はすべて不変です。
date クラス
date
クラスは日付 (年、月、日で構成される) を表し、そのプロトタイプは次のとおりです。 datetime.date( year, month, day)
パラメータの説明:
- 年の範囲は [MINYEAR, MAXYEAR]、つまり [1, 9999] です。 ;
- day の最大値は、指定された年と月のパラメーターに従って決定されます。たとえば、うるう年の 2 月は 29 日あり、
- date クラスは、一般的に使用されるクラス メソッドと属性を定義します。 #date.max
date.min
: 日付オブジェクトが表すことができる最大および最小の日付;date.resolution: 日付オブジェクト 日付を表す最小単位。ここは天国です。
date.today(): 現在のローカル日付を表す日付オブジェクトを返します;
date .fromtimestamp(timestamp): 指定されたタイムスタンプに基づいて日付オブジェクトを返します;
-
datetime.fromordinal(ordinal): グレゴリオ暦時間を返します日付オブジェクトに変換します (グレゴリオ暦: 我が国の太陰暦に似た暦表現方法で、西洋諸国でより一般的に使用されているため、ここでは詳しく説明しません)。 使用例:
>>> datetime.date.max datetime.date(9999, 12, 31) >>> datetime.date.min datetime.date(1, 1, 1) >>> datetime.date.resolution datetime.timedelta(1) >>> datetime.date.today() datetime.date(2016, 5, 12) >>> datetime.date.fromtimestamp(time.time()) datetime.date(2016, 5, 12)
ログイン後にコピーdate が提供するインスタンス メソッドとプロパティ: -
##date.year
、 date.month
date.day
: 年、月、日;-
date.replace(年、月、日): 新しいdate オブジェクトの場合は、パラメータで指定された年、月、日を使用して、元のオブジェクトの属性を置き換えます。 (元のオブジェクトは変更されません) date.timetuple()
: 日付に対応する time.struct_time オブジェクトを返します; -
#date.toordinal(): 日付に対応するグレゴリオ暦の日付を返します;
date.weekday():月曜日の場合は Weekday を返し、火曜日の場合は 1 を返し、以下同様;
data.isoweekday(): 平日を返します。月曜日の場合は 1 が返され、火曜日の場合は 2 が返され、以下同様;
date.isocalendar(): 戻り値の形式は次のとおりです。 as (年、月、日) タプル;
date.isoformat(): 'YYYY-MM-DD' の形式で文字列を返します;
date.strftime(fmt): カスタム形式の文字列。
使用例:
date は単純な演算子をオーバーロードします:>>> today = datetime.date.today() >>> today.year 2016 >>> today.month 5 >>> today.day 12 >>> tomorrow = today.replace(day=13) >>> tomorrow datetime.date(2016, 5, 13) >>> tomorrow.timetuple() time.struct_time(tm_year=2016, tm_mon=5, tm_mday=13, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=4, tm_yday=134, tm_isdst=-1) >>> tomorrow.toordinal() 736097 >>> tomorrow.weekday() 4 >>> tomorrow.isoweekday() 5 >>> tomorrow.isocalendar() (2016, 19, 5) >>> tomorrow.isoformat() '2016-05-13' >>> tomorrow.strftime("%y-%m-%d") '16-05-13'
ログイン後にコピーdate では日付の加算、減算、比較が可能です: -
日付に間隔を追加して、新しい日付オブジェクトを返します
- date2 = date1 - timedelta
:
日付は間隔で区切られ、新しい日付オブジェクトを返します
- timedelta = date1 - date2
:
2 つの日付を減算し、時間間隔オブジェクトを返します
- date1 < date2
:
2 つの日付を比較します。
使用例:
>>> now = datetime.date.today() >>> now datetime.date(2016, 5, 12) >>> now += datetime.date.resolution >>> now datetime.date(2016, 5, 13) >>> now -= datetime.date.resolution >>> now datetime.date(2016, 5, 12) >>> now < datetime.date.max True
- Time クラス
time クラスは時間 (時、分、秒、マイクロ秒で構成される) を表し、そのプロトタイプは次のとおりです。以下のように:
class datetime.time(hour=0, minutes=0, Second=0, microsecond=0, tzinfo=None)
パラメータの説明:
hour 的范围为[0, 24),
minute 的范围为[0, 60),
second 的范围为[0, 60),
microsecond 的范围为[0, 1000000),
tzinfo 表示时区信息。
time 类定义的类属性:
time.min、time.max:time类所能表示的最小、最大时间。其中,time.min = time(0, 0, 0, 0), time.max = time(23, 59, 59, 999999);
time.resolution:时间的最小单位,这里是1微秒;
使用示例:
>>> datetime.time.min datetime.time(0, 0) >>> datetime.time.max datetime.time(23, 59, 59, 999999) >>> datetime.time.resolution datetime.timedelta(0, 0, 1)<h4 id="time类提供的实例方法和属性">time类提供的实例方法和属性:</h4> <ul class=" list-paddingleft-2"> <li><p><strong>time.hour</strong>、<strong>time.minute</strong>、<strong>time.second</strong>、<strong>time.microsecond</strong>:时、分、秒、微秒;</p></li> <li><p><strong>time.tzinfo</strong>:时区信息;</p></li> <li><p><strong>time.replace</strong>([hour[, minute[, second[, microsecond[, tzinfo]]]]]):创建一个新的时间对象,用参数指定的时、分、秒、微秒代替原有对象中的属性(原有对象仍保持不变);</p></li> <li><p><strong>time.isoformat()</strong>:返回型如"HH:MM:SS"格式的字符串表示;</p></li> <li><p><strong>time.strftime(fmt)</strong>:返回自定义格式化字符串。</p></li> </ul> <p>使用示例:</p> <pre class="brush:php;toolbar:false">>>> tm = datetime.time(18, 18, 18) >>> tm.hour 18 >>> tm.minute 18 >>> tm.second 18 >>> tm.microsecond 0 >>> tm.tzinfo >>> tm.isoformat() '18:18:18' >>> tm.replace(hour=20) datetime.time(20, 18, 18) >>> tm.strftime("%I:%M:%S %p") '06:18:18 PM'
time 类的对象只能进行比较,无法进行加减操作。
datetime 类
datetime 是 date 与 time 的结合体,包括 date 与 time 的所有信息。其原型如下:
class datetime.datetime(year, month, day, hour=0, minute=0, second=0, microsecond=0, tzinfo=None)
各参数的含义与date、time的构造函数中的一样,要注意参数值的范围。
datetime类定义的类属性与方法:
datetime.min、datetime.max:datetime所能表示的最小值与最大值;
datetime.resolution:datetime最小单位;
datetime.today():返回一个表示当前本地时间的datetime对象;
datetime.now([tz]):返回一个表示当前本地时间的datetime对象,如果提供了参数tz,则获取tz参数所指时区的本地时间;
datetime.utcnow():返回一个当前utc时间的datetime对象;
datetime.fromtimestamp(timestamp[, tz]):根据时间戮创建一个datetime对象,参数tz指定时区信息;
datetime.utcfromtimestamp(timestamp):根据时间戮创建一个datetime对象;
datetime.combine(date, time):根据date和time,创建一个datetime对象;
datetime.strptime(date_string, format):将格式字符串转换为datetime对象,data 与 time 类没有提供该方法。
使用示例:
>>> datetime.datetime.min datetime.datetime(1, 1, 1, 0, 0) >>> datetime.datetime.max datetime.datetime(9999, 12, 31, 23, 59, 59, 999999) >>> datetime.datetime.resolution datetime.timedelta(0, 0, 1) >>> print datetime.datetime.resolution 0:00:00.000001 >>> today = datetime.datetime.today() >>> today datetime.datetime(2016, 5, 12, 12, 46, 47, 246240) >>> datetime.datetime.now() datetime.datetime(2016, 5, 12, 12, 47, 9, 850643) >>> datetime.datetime.utcnow() datetime.datetime(2016, 5, 12, 4, 47, 42, 188124) >>> datetime.datetime.fromtimestamp(time.time()) datetime.datetime(2016, 5, 12, 12, 48, 40, 459676) >>> datetime.datetime.combine(datetime.date(1990, 10, 05), datetime.time(18, 18, 18)) datetime.datetime(1990, 10, 5, 18, 18, 18) >>> datetime.datetime.strptime("2010-04-07 01:48:16.234000", "%Y-%m-%d %H:%M:%S .%f") datetime.datetime(2010, 4, 7, 1, 48, 16, 234000)
datetime 的实例方法与属性
datetime类提供的实例方法与属性大部分功能与 date 和 time 类似,这里仅罗列方法名不再赘述:
datetime.year、month、day、hour、minute、second、microsecond、tzinfo:
datetime.date():获取date对象;
datetime.time():获取time对象;
datetime.replace([year[, month[, day[, hour[, minute[, second[, microsecond[, tzinfo]]]]]]]]):
*datetime.timetuple() *
*datetime.utctimetuple() *
datetime.toordinal()
datetime.weekday()
datetime.isocalendar()
datetime.isoformat([sep])
datetime.ctime():返回一个日期时间的C格式字符串,等效于time.ctime(time.mktime(dt.timetuple()));
datetime.strftime(format)
datetime 对象同样可以进行比较,或者相减返回一个时间间隔对象,或者日期时间加上一个间隔返回一个新的日期时间对象。
timedelta 类
datetime.timedelta 对象代表两个时间之间的的时间差,两个 date 或 datetime 对象相减时可以返回一个timedelta 对象。其原型如下:
class datetime.timedelta(days=0, seconds=0, microseconds=0, milliseconds=0, minutes=0, hours=0, weeks=0)
所有参数可选,且默认都是0,参数的值可以是整数,浮点数,正数或负数。
内部只存储days,seconds,microseconds,其他参数的值会自动按如下规则抓转换:
1 millisecond(毫秒) 转换成 1000 microseconds(微秒)
1 minute 转换成 60 seconds
1 hour 转换成 3600 seconds
1 week转换成 7 days
三个参数的取值范围分别为:
-
0 <= microseconds < 1000000
0 <= seconds < 3600*24 (the number of seconds in one day)
-999999999 <= days <= 999999999
timedelta 类定义的类属性:
timedelta.min:时间间隔对象的最小值,即 timedelta(-999999999).
timedelta.max:时间间隔对象的最大值,即 timedelta(days=999999999, hours=23, minutes=59, seconds=59, microseconds=999999).
timedelta.resolution:时间间隔的最小单位,即 timedelta(microseconds=1).
使用示例:
>>> datetime.timedelta.min datetime.timedelta(-999999999) >>> datetime.timedelta.max datetime.timedelta(999999999, 86399, 999999) >>> datetime.timedelta.resolution datetime.timedelta(0, 0, 1) >>> print datetime.timedelta.resolution 0:00:00.000001</p> <h4 id="timedelta-实例方法">timedelta 实例方法</h4> <ul class=" list-paddingleft-2"><li><p><strong>timedelta.total_seconds()</strong>:计算时间间隔的总秒数</p></li></ul> <p>使用示例:</p> <pre class="brush:php;toolbar:false">>>> datetime.timedelta.resolution.total_seconds() 1e-06
格式字符串
datetime、date、time 都提供了 strftime() 方法,该方法接收一个格式字符串,输出日期时间的字符串表示。支持的转换格式如下:
%a星期的简写。如 星期三为Web %A星期的全写。如 星期三为Wednesday %b月份的简写。如4月份为Apr %B月份的全写。如4月份为April %c: 日期时间的字符串表示。(如: 04/07/10 10:43:39) %d: 日在这个月中的天数(是这个月的第几天) %f: 微秒(范围[0,999999]) %H: 小时(24小时制,[0, 23]) %I: 小时(12小时制,[0, 11]) %j: 日在年中的天数 [001,366](是当年的第几天) %m: 月份([01,12]) %M: 分钟([00,59]) %p: AM或者PM %S: 秒(范围为[00,61],为什么不是[00, 59],参考python手册~_~) %U: 周在当年的周数当年的第几周),星期天作为周的第一天 %w: 今天在这周的天数,范围为[0, 6],6表示星期天 %W: 周在当年的周数(是当年的第几周),星期一作为周的第一天 %x: 日期字符串(如:04/07/10) %X: 时间字符串(如:10:43:39) %y: 2个数字表示的年份 %Y: 4个数字表示的年份 %z: 与utc时间的间隔 (如果是本地时间,返回空字符串) %Z: 时区名称(如果是本地时间,返回空字符串) %%: %% => %
使用示例:
>>> dt = datetime.datetime.now() >>> dt.strftime('%Y-%m-%d %H:%M:%S %f') '2016-05-12 14:19:22 333943' >>> dt.strftime('%y-%m-%d %I:%M:%S %p') '16-05-12 02:19:22 PM' >>> dt.strftime("%a") 'Thu' >>> dt.strftime("%A") 'Thursday' >>> dt.strftime("%b") 'May' >>> dt.strftime("%B") 'May' >>> dt.strftime("%c") 'Thu May 12 14:19:22 2016' >>> dt.strftime("%x") '05/12/16' >>> dt.strftime("%X") '14:19:22' >>> dt.strftime("%w") '4' >>> dt.strftime("%j") '133' >>> dt.strftime("%u") '4' >>> dt.strftime("%U") '19'
以上がPython の datetime モジュールの概要 (例付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHPとPythonには独自の利点と短所があり、選択はプロジェクトのニーズと個人的な好みに依存します。 1.PHPは、大規模なWebアプリケーションの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンスと機械学習の分野を支配しています。

CentOSシステムでのPytorchモデルの効率的なトレーニングには手順が必要であり、この記事では詳細なガイドが提供されます。 1。環境の準備:Pythonおよび依存関係のインストール:Centosシステムは通常Pythonをプリインストールしますが、バージョンは古い場合があります。 YumまたはDNFを使用してPython 3をインストールし、PIP:sudoyumupdatepython3(またはsudodnfupdatepython3)、pip3install-upgradepipをアップグレードすることをお勧めします。 cuda and cudnn(GPU加速):nvidiagpuを使用する場合は、cudatoolをインストールする必要があります

DockerはLinuxカーネル機能を使用して、効率的で孤立したアプリケーションランニング環境を提供します。その作業原則は次のとおりです。1。ミラーは、アプリケーションを実行するために必要なすべてを含む読み取り専用テンプレートとして使用されます。 2。ユニオンファイルシステム(UnionFS)は、違いを保存するだけで、スペースを節約し、高速化する複数のファイルシステムをスタックします。 3.デーモンはミラーとコンテナを管理し、クライアントはそれらをインタラクションに使用します。 4。名前空間とcgroupsは、コンテナの分離とリソースの制限を実装します。 5.複数のネットワークモードは、コンテナの相互接続をサポートします。これらのコア概念を理解することによってのみ、Dockerをよりよく利用できます。

Pytorch GPUアクセラレーションを有効にすることで、CentOSシステムでは、PytorchのCUDA、CUDNN、およびGPUバージョンのインストールが必要です。次の手順では、プロセスをガイドします。CUDAおよびCUDNNのインストールでは、CUDAバージョンの互換性が決定されます。NVIDIA-SMIコマンドを使用して、NVIDIAグラフィックスカードでサポートされているCUDAバージョンを表示します。たとえば、MX450グラフィックカードはCUDA11.1以上をサポートする場合があります。 cudatoolkitのダウンロードとインストール:nvidiacudatoolkitの公式Webサイトにアクセスし、グラフィックカードでサポートされている最高のCUDAバージョンに従って、対応するバージョンをダウンロードしてインストールします。 cudnnライブラリをインストールする:

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

CentOSでPytorchバージョンを選択する場合、次の重要な要素を考慮する必要があります。1。CUDAバージョンの互換性GPUサポート:NVIDIA GPUを使用してGPU加速度を活用したい場合は、対応するCUDAバージョンをサポートするPytorchを選択する必要があります。 NVIDIA-SMIコマンドを実行することでサポートされているCUDAバージョンを表示できます。 CPUバージョン:GPUをお持ちでない場合、またはGPUを使用したくない場合は、PytorchのCPUバージョンを選択できます。 2。PythonバージョンPytorch

NGINXのインストールをインストールするには、次の手順に従う必要があります。開発ツール、PCRE-Devel、OpenSSL-Develなどの依存関係のインストール。 nginxソースコードパッケージをダウンロードし、それを解凍してコンパイルしてインストールし、/usr/local/nginxとしてインストールパスを指定します。 nginxユーザーとユーザーグループを作成し、アクセス許可を設定します。構成ファイルnginx.confを変更し、リスニングポートとドメイン名/IPアドレスを構成します。 nginxサービスを開始します。依存関係の問題、ポート競合、構成ファイルエラーなど、一般的なエラーに注意する必要があります。パフォーマンスの最適化は、キャッシュをオンにしたり、ワーカープロセスの数を調整するなど、特定の状況に応じて調整する必要があります。

CentOSシステムのPytorchデータを効率的に処理するには、次の手順が必要です。依存関係のインストール:システムを最初に更新し、Python3とPIPをインストールします。仮想環境構成(推奨):Condaを使用して、新しい仮想環境を作成およびアクティブにします。例:Condacreate-N
