python相对路径的引用注意事项

1 篇文章 0 订阅
1 篇文章 0 订阅

在上一篇文章中(python工程中使用logging_sogobaidu的博客-CSDN博客)提到了loggingConfig引入yaml配置文件,在使用systemctl启动工程后,logging日志没有打印出来。但是,在工程里面下直接使用python3 ****.py时,日志是可以正常打印。当时没找到原因,今天发现了原因。讲原因前,先说下python如何定位path的。

1、path = os.path.abspath(__file__)

获取到的path是.py文件存在的目录。

2、path = os.path.abspath('.')

获取到的是执行python3时所在的目录。

3、在loggingBuild.py中引用yaml文件时,没有使用绝对路径。我们一般理解,没有使用绝对路径,python应该是在文件的同级目录下查找yaml文件。但是,根据观察,python不是在.py文件的同级目录下查询yaml文件,而是在执行启动命令时所在的目录中查找yaml。

4、systemctl start reminder是root用户启动,目录是默认的 / 根目录。这就导致loggingBuild.py未能够查找到yaml文件,导致日志无法正确打印。

5、以上弯路主要还是因为对python的基本概念不了解导致的。python从10多年前陆陆续续的使用,但是真没有在工程上使用,也没有详细的看过Python的原理。

6、对loggingBuild.py进行了调整,以loggingBuild.py文件的绝对路径为基础,拼接出完整的yaml的绝对路径。

import yaml
import logging.config
import os


path = os.path.abspath(__file__)
for i in range(1):
    path = os.path.dirname(path)
    print(path)

path = os.path.join(path, 'loggingConfig.yaml')

if os.path.exists(path):
    with open(path, "r") as f:
        # 1.config=yaml.load(stream,Loader=yaml.FullLoader)
        # 2.config=yaml.safe_load(stream)
        # 3.config = yaml.load(stream, Loader=yaml.CLoader)
        config = yaml.load(f, Loader=yaml.FullLoader)
        logging.config.dictConfig(config)

systemctl start reminder

可以看到日志正常的打印出来:

pi@raspberrypi4:/ $ tail -100f info.log
2022-01-16 20:58:18,897 - commonRemindForWeather - 191 - INFO - 3069516608 - {'Linux': '/home/pi/Music/t0.mp3', 'Windows': 'C:/Users/Administrator/Downloads/t0.mp3'}
2022-01-16 20:58:18,897 - commonRemindForWeather - 192 - INFO - 3069516608 - Linux
2022-01-16 20:58:18,913 - commonRemindForWeather - 205 - INFO - 3069516608 - holiday.getStatus()=H
2022-01-16 20:58:18,915 - commonRemindForWeather - 216 - INFO - 3069516608 - 3.36
2022-01-16 20:58:25,864 - commonRemindForWeather - 191 - INFO - 3069516608 - {'Linux': '/home/pi/Music/sunny_new.mp3', 'Windows': 'C:/Users/Administrator/Downloads/sunny_new.mp3'}
2022-01-16 20:58:25,866 - commonRemindForWeather - 192 - INFO - 3069516608 - Linux
2022-01-16 20:58:25,872 - commonRemindForWeather - 205 - INFO - 3069516608 - holiday.getStatus()=H
2022-01-16 20:58:25,877 - commonRemindForWeather - 216 - INFO - 3069516608 - 3.456
2022-01-16 20:58:32,970 - commonRemindForWeather - 191 - INFO - 3069516608 - {'Linux': '/home/pi/Music/t1.mp3', 'Windows': 'C:/Users/Administrator/Downloads/t1.mp3'}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值