`
phyeas
  • 浏览: 164942 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
社区版块
存档分类
最新评论

监听文件变化、python和GIL

阅读更多

1、利用windows api对文件系统进行监听

尝试1:利用FindFirstChangeNotificationA、WaitForMultipleObjects、FindNextChangeNotification组合

这一组合缺点是就api而言无法获取变更的文件名,还要自己遍历文件夹比对。放弃。

 

尝试2:CreateFileA、ReadDirectoryChangesW组合,完美的组合,可以获取到变更的文件名,唯一不足的是还要用一个函数来转换获取到的文件名(WideCharToMultiByte)。

 

2、关于python调用c语言。使

用distutils可以将c程序编译成pyd,然后倒入到python程序中调用。

 

3、由于GIL的关系

由于GIL的关系,在调用c程序时,解释器会被锁住,直到c调用结束才释放(也可以自己释放,函数组:PyEval_AcquireLock();PyEval_ReleaseLock();),在监听等待操纵系统通知的时候是阻塞的,锁住之后再被阻塞,程序就不动了,于是便利用popen来调用。在c程序中以printf来与python程序交互。(感谢RednaxelaFX)

 

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>

int main(int argcount, char** args) {
	if(argcount != 2){
		return EXIT_SUCCESS;
	}
	char* path = args[1];
	HANDLE hDir = CreateFileA(path, FILE_LIST_DIRECTORY, FILE_SHARE_READ | FILE_SHARE_DELETE, NULL, OPEN_EXISTING, FILE_FLAG_BACKUP_SEMANTICS, NULL);
	FILE_NOTIFY_INFORMATION Buffer[1024];
	DWORD BytesReturned;
	int i = 0;
	if (ReadDirectoryChangesW(hDir, &Buffer, sizeof(Buffer), TRUE, FILE_NOTIFY_CHANGE_CREATION | FILE_NOTIFY_CHANGE_LAST_WRITE | FILE_NOTIFY_CHANGE_SIZE
			| FILE_NOTIFY_CHANGE_DIR_NAME | FILE_NOTIFY_CHANGE_FILE_NAME, &BytesReturned, NULL, NULL)) {
		for (i = 0; i < BytesReturned; i++) {
			if (Buffer[i].FileNameLength > 0) {
				char* action = "_default_";
				switch (Buffer[i].Action) {
				case FILE_ACTION_ADDED:
					action = "added";
					break;
				case FILE_ACTION_REMOVED:
					action = "removed";
					break;
				case FILE_ACTION_MODIFIED:
					action = "modified";
					break;
				case FILE_ACTION_RENAMED_OLD_NAME:
					action = "renamed_old_name";
					break;
				case FILE_ACTION_RENAMED_NEW_NAME:
					action = "renamed_new_name";
					break;
				case FILE_ACTION_ADDED_STREAM:
					action = "ADDED_STREAM";
					break;
				case FILE_ACTION_ID_NOT_TUNNELLED:
					action = "ID_NOT_TUNNELLED";
					break;
				case FILE_ACTION_MODIFIED_STREAM:
					action = "MODIFIED_STREAM";
					break;
				case FILE_ACTION_REMOVED_BY_DELETE:
					action = "REMOVED_BY_DELETE";
					break;
				case FILE_ACTION_REMOVED_STREAM:
					action = "REMOVED_STREAM";
					break;
				case FILE_ACTION_TUNNELLED_ID_COLLISION:
					action = "TUNNELLED_ID_COLLISION";
					break;
				}
				char path[MAX_PATH];
				WideCharToMultiByte(CP_ACP, 0, Buffer[i].FileName, Buffer[i].FileNameLength, path, sizeof(path), NULL, FALSE);
				printf("%s:%s", action, path);
				break;
			}
		}
	}

	return EXIT_SUCCESS;
}

 

os.popen("FileSystemChangeListener.exe %s" % self.path).read()

 

分享到:
评论
4 楼 jamiesun 2010-01-06  
因为最近听说qq的某些流氓行为,同时也观察了其他软件如360系列,发现都有后台乱搞的毛病,我想是不是自己diy个啥来监控下。不过python直接对底层还是弱了点
3 楼 RednaxelaFX 2010-01-06  
我一般用FileMon...
2 楼 phyeas 2010-01-06  
  这个,我google一下先
1 楼 jamiesun 2010-01-06  
如果想监视某进程(比如qq)对电脑文件的访问情况,有什么好办法

相关推荐

    python SocketServer C++ 实现

    注意,由于C++的并发模型和Python的GIL(全局解释器锁)不同,因此C++版本的服务器可能会在处理多客户端并发时表现出不同的性能特征。 总之,C++实现的SocketServer类可以提供类似Python的便捷服务端编程体验,同时...

    Python语言实现http服务器

    在这个项目中,我们使用Python编写了一个多线程的HTTP服务器,这对于学习和测试网页应用或者本地文件共享都非常有用。接下来,我们将详细探讨Python实现HTTP服务器的关键知识点。 1. **Python内置HTTP服务器模块**:...

    tcp_service_pythonTCP_python_

    2. **创建TCP套接字**:使用`socket.socket()`函数创建一个TCP套接字,然后通过`bind()`绑定到指定的IP和端口,最后调用`listen()`来开始监听连接。 ```python server_socket = socket.socket(socket.AF_INET, ...

    python多线程编程实现网络串口透传

    在Python多线程编程中,需要注意GIL(全局解释器锁)的存在,虽然Python的多线程在CPU密集型任务上可能表现不佳,但在I/O密集型任务(如网络和串口通信)中,由于线程间等待I/O的时间较长,多线程仍能有效提高程序...

    python Game Server

    Python的多线程或多进程可以解决这个问题,但Python的全局解释器锁(GIL)可能导致并发性能限制。因此,可能采用了非阻塞I/O模型,如异步编程(asyncio库)或者第三方库如Twisted或Tornado来提高并发性能。 6. **...

    用Stackless Python建立聊天室服务器.zip

    在Stackless Python中,我们可以创建一个主循环,用于监听新的连接,接收和发送数据。通过创建协程(coroutines)或通道(channels),我们可以实现数据在不同任务间的异步传递。 3. **用户认证**:为了确保安全性...

    1.Python基础.md

    - **epoll**:相比于select和poll更加高效,因为它不会遍历整个被监听的文件描述符列表,而是只做必要的检查。 #### 装饰器 - **概念**:装饰器是一种特殊的语法结构,允许我们在不修改原函数的情况下为其添加新...

    python中的并发学习原书高清PDF附随书代码

    - **GIL(全局解释器锁)**:Python解释器的特性,使得任何时刻只有一个线程在执行。这限制了多线程在CPU密集型任务中的性能提升,但对I/O密集型任务影响较小。 - **greenlet和gevent**:这些第三方库通过用户空间...

    Python网络编程基础

    学习如何创建、绑定、监听、接受连接和发送/接收数据是掌握Python网络编程的关键。 5. **多线程与并发处理** 在网络编程中,为了提高服务效率,往往需要处理多个并发连接。Python的threading模块可以用来创建和...

    kivy指南.zip 开源Python函式库

    4. **Multithreading**:尽管Python的GIL(全局解释器锁)限制了多线程,但Kivy通过其事件循环和异步操作实现了非阻塞的用户体验。这使得UI可以保持流畅,即使在执行耗时任务时也是如此。 5. **OpenGL支持**:Kivy...

    python烟花修,过年烟花

    3. **随机数**:为了让烟花秀看起来自然且富有变化,我们需要用到Python的`random`模块来生成随机的位置、颜色、速度和方向,这样每朵烟花都有独特的轨迹和效果。 4. **运动和动画**:烟花升空、绽放和消散的过程...

    python技能图谱.pdf

    - 涉及到socket编程、HTTP协议详解、TCP协议、echoserver和文件处理等。 11. Web开发: - 介绍Web开发中的常用技术,包括Requests库、XPath解析、Scrapy框架、Django和Flask框架等。 12. 数据库技术: - 包括...

    python入门到高级全栈工程师培训 第3期 附课件代码

    07 Python条件语句和基本数据类型 08 Python while循环语句以及练习题 09 练习题讲解 第10章 01 上节内容回顾以及补充 02 上周作业实现 03 Pycharm的安装和使用 04 Python 运算符 05 Python 运算符以及总结 06 ...

    pythonProject_sdffsdf_

    但需要注意的是,Python的全局解释器锁(GIL)会限制同一时间只有一个线程执行Python字节码,这意味着多线程在Python中并不能实现真正的并行计算。不过,对于I/O密集型任务,线程可以交替运行,依然能提升程序响应...

    python socket两个客户端相互聊天 聊天室功能

    不过,Python的全局解释器锁(GIL)限制了多线程的并行执行,因此在性能要求较高的情况下,多进程可能更为合适。 6. **异常处理**: 在编写socket程序时,应考虑到各种可能的网络异常,如连接中断、超时、数据传输...

    Python并发编程专题.zip

    Python并发编程是Python编程中的一个重要领域,特别是在处理大数据、网络编程和实时系统时,它能够显著提高程序的执行效率。本专题将深入探讨Python中实现并发的各种方法和技术。 首先,我们要理解什么是并发。并发...

    python课件-第13章 多线程与多进程编程.ppt

    在Python编程中,多线程...总结来说,Python的多线程编程提供了丰富的API来实现线程的创建、管理和同步,但在追求高性能计算时,可能需要借助多进程或第三方库如`multiprocessing`来绕过GIL限制,实现真正的并行计算。

    Python web全栈学习路线.docx

    本资源摘要信息涵盖了 Python Web 全栈开发的学习路线,从 Linux 运维到 Python 基础、前端开发、数据库和缓存等方面都有所涉及。 Linux 运维 * Linux 安装 * 网络基础知识点 * ISO 七层模型 * Linux 基本命令 * ...

    python入门教程-02-静态web服务器-多任务版.ev4.rar

    在学习了这些基础知识后,你就可以通过观看"python入门教程-02-静态web服务器-多任务版.ev4.mp4"视频,进一步深入了解Python构建静态Web服务器的实践操作和多任务处理的具体实现。视频中可能涵盖了如何配置服务器,...

    python 实现的多进程 socket通讯框架,支持多进程进行发送和接收

    下面将详细介绍Python的多进程和Socket编程相关的知识。 首先,我们来了解Python的多进程编程。在Python中,`multiprocessing`模块提供了创建和管理进程的功能。它与`threading`模块类似,但进程之间拥有独立的内存...

Global site tag (gtag.js) - Google Analytics