如何监控游戏地址值?

2024-05-20 17:09:16 发布

您现在位置:Python中文网/ 问答频道 /正文

在尝试分解GitHub的代码并找到任何关于这个的youtube视频之后,我开始放弃了,所以我希望你们中的一个能帮助我。我所要做的就是监视一个游戏内存地址值。例如,假设在游戏Minecraft中,健康值和内存地址是:

地址:001F6498

值:20

如何在Python中将此值转换为变量?你知道吗

代码思维过程:

import pywin32

pid = 5601
address = 001F6498 

ReadProcessMemory(pid, address):
    print(Value)

#In this example i would like it to print 20

Tags: 代码importgithub游戏视频youtubeaddress地址
1条回答
网友
1楼 · 发布于 2024-05-20 17:09:16

你需要先掌握这个过程。下面是一些使用OpenProcess()FindWindow()和GetWindowThreadProcessId()获取进程句柄的代码。还包括一个小函数来正确读取正确的大小变量并正确存储它。此方法可用于读取指针,利用“i”表示整数类型。你知道吗

import win32api
import win32gui
import win32process

from ctypes import *
from pymem import *

PROCESS_ALL_ACCESS = 0x1F0FFF
ReadProcessMemory = windll.kernel32.ReadProcessMemory

def read_memory(procId, address, type):
    buffer = (ctypes.c_byte * getlenght(type))()
    bytesRead = ctypes.c_ulonglong(0)
    readlenght = getlenght(type)
    ReadProcessMemory(procId, address, buffer, readlenght, byref(bytesRead))
    return struct.unpack(type, buffer)[0]


hWnd = win32gui.FindWindow(0, ("WINDOW NAME HERE"))

pid=win32process.GetWindowThreadProcessId(hWnd)
handle = pymem.Pymem()
handle.open_process_from_id(pid[1])
procBaseAddress = handle.process_base

hProc = windll.kernel32.OpenProcess(PROCESS_ALL_ACCESS, 0, pid[1])

value = ReadProcessMemory(hProc, ADDRESS_OF_VARIABLE_TO_READ, "i")

print(value)

归功于一个朋友,木偶大师,他教我怎么做

相关问题 更多 >