V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
mgna17
V2EX  ›  Python

关于监听一个文件的问题

  •  
  •   mgna17 · 2016-02-01 11:09:18 +08:00 · 2684 次点击
    这是一个创建于 3254 天前的主题,其中的信息可能已经有所发展或是发生改变。
    请教一下,有没有什么手段在 windows 环境下监控一个.xls 文件在内存中的改动?
    比如在某个 office 中打开了这个.xls 文件,做了修改但是没有保存,是否能够检测到这部分没有保存的改动?
    15 条回复    2016-02-01 16:09:10 +08:00
    knightdf
        1
    knightdf  
       2016-02-01 11:14:40 +08:00
    那是不可能的,改动的内容还在 office 的内存中,你是想读取其他进程的内存空间?也许有黑方法可以呢
    laucie
        2
    laucie  
       2016-02-01 11:16:04 +08:00
    @knightdf 受一拜
    mgna17
        3
    mgna17  
    OP
       2016-02-01 11:16:37 +08:00
    @knightdf 唔。。。。 好吧,那么我去看看 pyusb 。。。
    mfaner
        4
    mfaner  
       2016-02-01 12:03:03 +08:00
    office 不是有自动恢复吗,监视自动恢复文件以及读取这个不知可行吗
    mfaner
        5
    mfaner  
       2016-02-01 12:13:23 +08:00
    写个 office 插件吧,感觉靠谱
    MiguelValentine
        6
    MiguelValentine  
       2016-02-01 12:16:48 +08:00
    xls 改动时会保存到一个~文件名.xls 的文件。需要监听这个。但是 win 监听我也不懂。
    mgna17
        7
    mgna17  
    OP
       2016-02-01 12:38:43 +08:00
    @MiguelValentine 看过了,要跑脚本的那台机器上用的 office 是 wps ,没有那个临时文件(也可能是我不会找 - -) 如果是 msoffice 和 libreoffice 的话,应该是有这么个临时文件的。
    然后,我看了下自己电脑上的 libreoffice 生成的那个临时文件,里面就一句话:
    ,me,localhost.localdomain,01.02.2016 12:35,file:///home/me/.config/libreoffice/4;
    我要找的东西应该会在后面指向的那个路径里面,然而。。。里面错综复杂。 win 下面估计更加麻烦。
    所以额,现在我倒想试试看去监听 usb 输入了
    mgna17
        8
    mgna17  
    OP
       2016-02-01 12:43:58 +08:00
    @mfaner 凭我的功力还差得远呢。。。
    gamexg
        9
    gamexg  
       2016-02-01 13:05:24 +08:00 via Android
    另一个选择,你替他保存。
    拷贝并打开,定时保存。
    mgna17
        10
    mgna17  
    OP
       2016-02-01 13:32:47 +08:00
    @gamexg 这是一个好建议,就看如何实现了╮( ̄▽ ̄)╭
    gamexg
        11
    gamexg  
       2016-02-01 13:44:01 +08:00
    @mgna17 其实 ms office 是有接口的, wps 应该没有接口。
    曾经直接 python 操作 ms word 批量生成报表,可惜现在找不到代码了。
    mgna17
        12
    mgna17  
    OP
       2016-02-01 14:05:27 +08:00
    @gamexg 换个 office 倒也不是什么大事,问题是,要如何命令一个已经打开了的 ms office 保存它的文档呢,有这方面的相关文档吗,请允许我无耻的伸个手 o(///▽///)o
    gamexg
        13
    gamexg  
       2016-02-01 14:45:37 +08:00
    自己写个程序设置为 xls 默认打开方式,我当时是修改 word , excel 的没做过,下面是搜索的的一个 excel 的教程。 google 关键字 python office 操作 Excel

    http://ictar.github.io/2015/11/06/%E7%94%A8python%E6%93%8D%E7%BA%B5Microsoft%20Office%E4%B9%8BExcel/
    louk78
        14
    louk78  
       2016-02-01 14:54:42 +08:00
    得到改动前和改动后文件 handler ,比对出不相同的地方
    mgna17
        15
    mgna17  
    OP
       2016-02-01 16:09:10 +08:00
    @gamexg 非常感谢
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2524 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 05:31 · PVG 13:31 · LAX 21:31 · JFK 00:31
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.