【Python】ロギングのコンフィグで環境設定- fileConfig(), dictConfig()

Pythonの応用
スポンサーリンク

初心者の独学でのプログラミング学習はとてもツライ…

プログラミングをマスターしたい!

今のIT業界はプログラミングエンジニアが不足していると言われています。
高収入の職業とも言われる分野もありますし、AI、機械学習、ディープラーニング、IOTといった注目される分野が目白押しです。

でも、いざ初心者がプログラミングをマスターしようとすると…

  • 本を読んだりネットの記事で自力で勉強しているけど限界を感じる
  • プログラミングスクールに定期的に通うのは面倒だ
  • 地方に住んでると家の近くにプログラミングスクールなんてない
  • どのプログラミング言語を学べばいいのか悩む
  • 実際の就職や転職にプログラミングが活かせるのか心配だ

など、プログラミングを自分で勉強しようとすると悩みが尽きません。

プログラミングに詳しい友人に教えてもらおうと思っても、そんな友人なんて滅多にいません。いたとしても細かく教えてくれるほど時間に余裕がある人はいないでしょう。

そんな独学でプログラミングをマスターするのに限界を感じてる方に、オンラインプログラミングスクールをがおすすめです。

おすすめのオンラインスクールはこちら

ここではPythonを使ったロギングの環境設定(config)について見ていこうと思います。

ロギングは3種類の方法で設定することができます。

まず、設定メソッドを呼び出すPythonコードを明示的に使って、ロガー、ハンドラ、フォーマッタを生成する方法で、これまでにすでにやってきた方法です。

残りの2つは、ロギングの設定ファイルを作り、それをfileConfig()関数を使って読み込む方法と、設定情報を辞書型で記述し、それをdictConfig()関数に渡す方法があります。

Logging HOWTO — Python 3.8.0 ドキュメント

ここではこのfileConfig()とdictConfig()を使った方法を見ていきましょう。

スポンサーリンク

fileConfig()でiniファイルを読み込む

ロギングの設定ファイルを作り、それをfileConfig()関数を使って読み込む方法から見ていきましょう。

まず、メインの処理を行うコードを次のように書いてみます。ここでのファイル名はlogging_lesson.pyとしています。

これまでのログ出力のコードとほぼ同じようなコードです。

違うところはlogging.confgをインポートしているところと、fileConfig()でlogging.iniファイルを読み込んでいるところです。

ここでfileConfig()で読み込むlogging.iniファイルを作って設定を記述してみます。ここでは公式ドキュメントにある設定を利用しています。

このファイルと同じ作業ディレクトリに保存して、ターミナルで実行してみます。

logging.iniの最終行で記述しているフォーマットで結果が表示されます。

logging.iniの部分のコード表示は、スペースの都合で途中までになっていますが、結果はWARNINGまでの表示となっています。これは、logging.iniの[logger_root]をlevel=WARNINGと指定し、メインのコードはgetLogger(__name__)としているからです。

ここで、logging.iniの[logger_simpleExample]がlevel=DEBUGとなっているので、メインのコードをgetLogger(simpleExample)にしてみます。

実行するとこうなります。

結果がDEBUGまで表示されているのがわかります。

スポンサーリンク

dictConfig()に辞書型データの設定を渡す

設定情報を辞書型で記述し、dictConfig()関数に渡す方法を見ていきます。

上記のlogging.iniに記述していた設定情報をdict型で記述し、dictConfig()に次のように渡します。

実行するとこうなります。

DEBUGまで表示されているのがわかります。

logging.iniファイルで設定するよりも、このdictConfig()で記述した設定ファイルを使って開発することが多いそうです。

スポンサーリンク

まとめ

ここではPythonを使ったロギングの環境設定(config)について扱いました。

ロギングの設定には、既に別のところで扱ったように、設定メソッドを呼び出すPythonコードを明示的に使って、ロガー、ハンドラ、フォーマッタを生成してきましたが、ここでは、ロギングの設定ファイルを作ってfileConfig()関数を使って読み込む方法と、設定情報を辞書型で記述し、それをdictConfig()関数に渡す方法を見てきました。

fileConfig()を使ってlogging.iniファイルなどを利用するよりも、dictConfig()で記述した設定ファイルを使って開発する場面が多いようなので、このあたりも念頭に置いておくと良いでしょう。

自宅学習はオンラインプログラミングスクールを活用!

自宅学習にはオンラインプログラミングスクールがおすすめ!

オンラインプログラミングスクールは独学でプログラミングを学習する時のデメリットを解消する仕組みが備わっています。

気になるところは…

学習がオンラインで完結するのはもちろんですが、独学ではできない質問サポートがあるかどうか。わからないことを現役のエンジニアが質問に答えてくれるといいですよね。

受講者個人に担当のメンターがつき、マンツーマンで学習の相談に乗ってくれることも必要で、ITエンジニアの世界についても伺えたりもすると幅が広がります。

オンライン面談だけでなく、チャット機能を使って気軽に質問を投げかけることができることも大切です。

また、オリジナルプロダクトの開発とサポートがコースの中に組み込まれていて、独学ではなかなか難しい実践的なスキルの習得にもつなげたい。

プログラミングをマスターした後の実際の仕事につながる転職サポートでがあると、ITエンジニアの世界に飛び込むのに不安が解消されます。

そんな豊富なメニューが揃っているおすすめのオンラインプログラミングスクールがこちらにあります。

おすすめのオンラインプログラミングスクールはこちら

TechAcademyはおすすめのオンラインプログラミングスクール!

オンラインのプログラミングスクールでは、テックアカデミーの充実度が目を見張ります。

オンラインで受講が完結するので、自宅学習でプログラミングをマスターしたい人にはテックアカデミーがおすすめです。

メンター制度も現役のプロが対応してくれます。大学生などが対応しているスクールに比べて本気度と専門性が違います。メンター制度の無いスクールもありますし、担当では無いメンターが対応するスクールもあったりするので、相談の質が違いますね。

チャットサポートもあるので、それが無いスクールに比べて相談の気軽さの違いがあります。

プロダクト開発のサポートで実践力が養われるだけでなく、どの講座を利用しても転職サポートが受けられるのはありがたい。

用意されているコースも、初心者向けのプログラミングコースから、Python、Java、PHP、iPhoneアプリ、AndroidといったITエンジニアのベースとなる主要な言語だけでなく、AI、データサイエンス、ブロックチェーン、webアプリケーションと行った実践的なコースまで用意しています。

他にも、webデザインやUI/UXデザイン、動画編集、webディレクションやwebマーケティングといったプログラミング以外での役立つコースまであります。

このようなたくさんの選択肢から自分にあったコースを選ぶことがでるのがテックアカデミーです。

コースの期間も短期間でマスターしたり、長期の受講でじっくり取り組むコースを選ぶこともできます。

複数講座のセットコースを利用することで大幅な割引が受けらるので、お得に受講することもできます。

無料体験もありますので、プログラミング学習でオンラインスクールを考えている人はTechAcademyをぜひ利用してみてください。

テックアカデミーの公式サイトはこちら

タイトルとURLをコピーしました