pyinstaller 打包 exe 后,运行异常

2019-12-02 18:49:02 +08:00
 bfqymmt

代码如下,在命令模式下运行 python demo.py 是是可以修改文件时间的。

采用:pyinstaller -F demo.py 打包 exe 后,无法修改文件时间。这会是什么问题呢?

from win32file import CreateFile, SetFileTime, GetFileTime, CloseHandle
from win32file import GENERIC_READ, GENERIC_WRITE, OPEN_EXISTING
from pywintypes import Time
import time
 
def modifyFileTime(filePath,createTime,modifyTime,accessTime,offset):
    """
    用来修改任意文件的相关时间属性,时间格式:YYYY-MM-DD HH:MM:SS 例如:2019-02-02 00:01:02
    :param filePath: 文件路径名
    :param createTime: 创建时间
    :param modifyTime: 修改时间
    :param accessTime: 访问时间
    :param offset: 时间偏移的秒数,tuple 格式,顺序和参数时间对应
    """
    try:
        format = "%Y-%m-%d %H:%M:%S" #时间格式
        cTime_t = timeOffsetAndStruct(createTime,format,offset[0])
        mTime_t = timeOffsetAndStruct(modifyTime,format,offset[1])
        aTime_t = timeOffsetAndStruct(accessTime,format,offset[2])
 
        fh = CreateFile(filePath, GENERIC_READ | GENERIC_WRITE, 0, None, OPEN_EXISTING, 0, 0)
        createTimes, accessTimes, modifyTimes = GetFileTime(fh)
 
        createTimes = Time(time.mktime(cTime_t))
        accessTimes = Time(time.mktime(aTime_t))
        modifyTimes = Time(time.mktime(mTime_t))
        SetFileTime(fh, createTimes, accessTimes, modifyTimes)
        CloseHandle(fh)
        return 0
    except:
        return 1
def timeOffsetAndStruct(times,format,offset):
    return time.localtime(time.mktime(time.strptime(times, format)) + offset)
 
#调用
cTime = "2019-02-02 00:01:02" # 创建时间
mTime = "2019-02-02 00:01:03" # 修改时间
aTime = "2019-02-02 00:01:04" # 访问时间
 
fName = r"E:\test.xlsx" #文件路径
offset = (0,1,2)  # 偏移的秒数
r=modifyFileTime(fName,cTime,mTime,aTime,offset)
if r==0:print('修改完成')
if r==1:print('修改失败')

3135 次点击
所在节点    Python
7 条回复
jdhao
2019-12-02 19:02:28 +08:00
多设几个 debug 输出看一下?
yonglanyouyou
2019-12-02 19:49:30 +08:00
pyinstaller --hiddenimport win32timezone -F demo.py
UnknownR
2019-12-02 20:11:37 +08:00
还需要更多的 log 才能确定问题。

要是跑在 windows 下可以用 powershell 写,比如[System.IO]这个类,Methods 里就包含了你需要的三个 time,直接有 set 的方法

try{
[System.IO]::SetCreationTime([String]<File PATH>, $cTime)
[System.IO]::SetLastWriteTime([String]<File PATH>, $mTime)
[System.IO]::SetAccessTime([String]<File PATH>, $aTime)
}
catch{
throw
}

https://docs.microsoft.com/en-us/dotnet/api/system.io.file.setlastwritetime?
1462326016
2019-12-03 08:55:54 +08:00
管理员试下?
Marsss
2019-12-03 09:12:03 +08:00
你要知道问题出在哪里,那就把日志导出来看看
try:
......
except Exception as e:
with open('log.txt', 'a') as f:
f.write(str(e))
zcfnc
2019-12-03 09:56:45 +08:00
遇事不决看日志
bfqymmt
2019-12-03 11:31:51 +08:00
@yonglanyouyou 可以了。太感谢你了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/625215

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX