【Python】ロギングのロガーで特定の処理のログ設定を変更する

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

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

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

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

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

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

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

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

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

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

Pythonを使ったロギングの機能をさらに見ていきましょう。

フォーマッタに続いて、ここではロガー(logger)を扱います。

basicConfig()を使ってログレベルを設定できるということは既に学びましたが、ロガーを使うことで、このログレベルの設定を引き継ぎながら、特定の処理のログレベルの設定を変更することができます。

スポンサーリンク

ロガーの設定

具体的に見ていきましょう。

単純なロギングのコードはこう書くことができます。

既に扱った内容ですので、特に問題はないはずです。ロギングのレベルをINFOにしています。

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

これにロガーの設定を加えていきましょう。

先ほどのコード追記していきます。

logging.getLogger()にファイル名を指定します。ここでは __name__ として自身のファイルであるrootを示しています。続けて、logging.setLevel()でレベルをにDEBUG指定し、logger.debug()で出力するようにしています。

これを実行してみるとこうなります。

INFOとDEBUGの両方が出力されているのがわかります。INFOはこれまでと同じで、DEBUGは__main__ ということで、これまでのロガーを持ってきてレベルを設定し直して出力し直しています。

スポンサーリンク

別ファイルでロガーを設定する

先ほどのgetLogger()には__name__を指定しましたが、別のnameを指定して使うことができます。これは別ファイルでロガーを作って、カスタマイズを加えて開発する時などに利用します。

具体的にやっていきましょう。

次のようなロガーを別ファイルに記述します。ここではファイル名をtestlogger.pyとしておきます。

loggerを設定して、do_something()という関数を作って出力処理を記述しています。

ここで、元のlogging_lesson.pyを次のように書き換えます。

先ほど作ったtestlogger.pyをモジュールとしてインポートしています。basicConfig()でログレベルを指定し、loggingの出力をしているところはこれまでと同じ。最後に、インポートしたモジュールからdo_something()を呼び出しています。

実行してみましょう。

ログを見ると、メインの処理はrootで表示されています。そして、testloggerとインポートしたロガーのファイル名が表示され、メッセージが表示されているのがわかります。

こうすることで、どこの処理が呼ばれているのかがわかります。

ロガー(testlogger.py)をもう少し書き換えてみます。

setLevel()を加えて、処理を追加しています。

これに合わせてメインの方(logging_lesson.py)も書き換えてみます。

メインの方でのgetLogger()を指定しています。

実行してみます。

これはメインのところでbasicConfig()でまずロギングの設定をして、それ以降はロガーを設定していくというやり方になります。

出力結果を見ていくと、どこがメインの処理で、何がパッケージやモジュールで呼ばれたものなのかがわかります。

スポンサーリンク

まとめ

Pythonを使ったロギングの機能について、ここではロガー(logger)を扱いました。

basicConfig()を使ってログレベルを設定したあとで、ロガーを使って、このログレベルの設定を引き継ぎながら、特定の処理のログレベルの設定を変更することができます。

このロガーを別モジュールとして設定して、様々なカスタマイズを施してインポートして開発に利用するようです。

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

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

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

気になるところは…

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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