300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > logging多进程报错:PermissionError: [WinError 32] 另一个程序正在使用此文件 进程无法访问

logging多进程报错:PermissionError: [WinError 32] 另一个程序正在使用此文件 进程无法访问

时间:2023-06-07 21:27:05

相关推荐

logging多进程报错:PermissionError: [WinError 32] 另一个程序正在使用此文件 进程无法访问

logging多进程报错:PermissionError: [WinError 32] 另一个程序正在使用此文件,进程无法访问

问题重现

-12-23 13:28:24,415 - INFO: 正在进行D:\Anaconda_program\hangtian_spider\hangkong/data/EI/01.txt文件<RECORD 216>记录的读取--- Logging error ---Traceback (most recent call last):File "D:\Anaconda3\lib\logging\handlers.py", line 72, in emitself.doRollover()File "D:\Anaconda3\lib\logging\handlers.py", line 173, in doRolloverself.rotate(self.baseFilename, dfn)File "D:\Anaconda3\lib\logging\handlers.py", line 113, in rotateos.rename(source, dest)PermissionError: [WinError 32] 另一个程序正在使用此文件,进程无法访问。: 'D:\\Anaconda_program\\hangtian_spider\\hangkong\\log\\ei_txt_file.log' -> 'D:\\Anaconda_program\\hangtian_spider\\hangkong\\log\\ei_txt_file.log.1'Call stack:File "D:\Anaconda3\lib\threading.py", line 884, in _bootstrapself._bootstrap_inner()File "D:\Anaconda3\lib\threading.py", line 916, in _bootstrap_innerself.run()File "D:\Anaconda3\lib\threading.py", line 864, in runself._target(*self._args, **self._kwargs)File "D:\Anaconda_program\hangtian_spider\hangkong\web\app\data\EI_Data.py", line 228, in get_ei_txt_fileread_txt(root_dir+file)File "D:\Anaconda_program\hangtian_spider\hangkong\web\app\data\EI_Data.py", line 260, in read_txtei_data.add_ei_data(re_dict)File "D:\Anaconda_program\hangtian_spider\hangkong\web\app\data\EI_Data.py", line 126, in add_ei_datalogger.info("本条记录中筛选的关键字段有:record_dict.keys(): {}".format(', '.join(record_dict.keys())))Message: '本条记录中筛选的关键字段有:record_dict.keys(): ei_an, ei_ti, ei_au, ei_af, ei_ca, ei_st, ei_ast, ei_vl, ei_is, ei_isd, ei_py, ei_pg, ei_la, ei_sn, ei_cn, ei_dt, ei_pu, ei_ab, ei_nr, ei_mh, ei_ctt, ei_uctt, ei_cfc, ei_di, ei_db, ei_cit'Arguments: ()-12-23 13:28:24,467 - INFO: 本条记录中筛选的关键字段有:record_dict.keys(): ei_an, ei_ti, ei_au, ei_af, ei_ca, ei_st, ei_ast, ei_vl, ei_is, ei_isd, ei_py, ei_pg, ei_la, ei_sn, ei_cn, ei_dt, ei_pu, ei_ab, ei_nr, ei_mh, ei_ctt, ei_uctt, ei_cfc, ei_di, ei_db, ei_cit--- Logging error ---

解决办法

from logging import getLogger, INFOfrom concurrent_log_handler import ConcurrentRotatingFileHandlerimport oslog = getLogger()# Use an absolute path to prevent file rotation trouble.logfile = os.path.abspath("mylogfile.log")# Rotate log after reaching 512K, keep 5 old copies.rotateHandler = ConcurrentRotatingFileHandler(logfile, "a", 512*1024, 5)log.addHandler(rotateHandler)log.setLevel(INFO)log.info("Here is a very exciting log message, just for you")

参考

/Preston-Landers/concurrent-log-handler

/chongtong/article/details/80831782

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。