欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Python實(shí)現(xiàn)獲取本機(jī)當(dāng)前用戶登陸過的微信ID

 更新時(shí)間:2025年07月15日 10:33:21   作者:JHC000000  
這篇文章主要為大家詳細(xì)介紹了如何使用Python實(shí)現(xiàn)獲取本機(jī)當(dāng)前用戶登陸過的微信對(duì)應(yīng)的wxid,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下

實(shí)現(xiàn)思路

本文將實(shí)現(xiàn)一個(gè)跨平臺(tái)的微信用戶ID(wxid)獲取工具,

DeviceUtils類提供靜態(tài)方法能自動(dòng)識(shí)別Windows、Linux和MacOS系統(tǒng),從微信配置文件中提取已登錄的wxid

  • Windows平臺(tái)讀取config.data文件
  • Linux/MacOS檢查特定目錄下的登錄文件夾

CMDUtils類提供命令行執(zhí)行功能,支持阻塞/非阻塞執(zhí)行及實(shí)時(shí)輸出處理

實(shí)現(xiàn)代碼

import os
import platform
import re
from utils.utils_cmd import CMDUtils


class DeviceUtils:
    """
    設(shè)備工具類
    """

    @staticmethod
    def get_wechat_wxid(folder=None):
        """
        獲取設(shè)備上登陸的 微信 wxid
        :param folder:僅針對(duì)Windows平臺(tái)自定義數(shù)據(jù)存儲(chǔ)路徑生效
        :return:
        """
        wxids = []
        system = DeviceUtils().get_system()
        if system == "Windows":
            if not folder:
                file = os.path.join(
                    os.environ['USERPROFILE'],
                    'Documents',
                    'WeChat Files',
                    'All Users',
                    'config',
                    'config.data'
                )
            else:
                file = os.path.join(
                    folder,
                    'All Users',
                    'config',
                    'config.data'
                )
            with open(file, "rb") as f:
                data = f.read()
            data_matches = re.findall(r'(wxid_.*?)\\\\config', str(data))
            if len(data_matches) > 0:
                wxids.extend(data_matches)
        elif system == "Linux":
            user = CMDUtils.run_await_results(cmd=['whoami'])
            for folder in ('文檔', 'Documents'):
                file = f'/home/{user}/{folder}/xwechat_files/all_users/login'
                if os.path.exists(file):
                    file_list = os.listdir(file)
                    if len(file_list) > 0:
                        for filename in file_list:
                            if filename.startswith('wxid_'):
                                wxids.append(filename)
        elif system == "Darwin":
            user = CMDUtils.run_await_results(cmd=['whoami'])
            file = f"/Users/{user}//Library/Containers/com.tencent.xinWeChat/Data/Documents/xwechat_files/all_users/login"
            if os.path.exists(file):
                file_list = os.listdir(file)
                if len(file_list) > 0:
                    for filename in file_list:
                        if filename.startswith('wxid_'):
                            wxids.append(filename)

        msg = f"{system} 識(shí)別到微信{len(wxids)}個(gè)" if len(wxids) > 0 else f"{system} 未識(shí)別到微信"
        print(msg)
        return wxids

    @staticmethod
    def get_system():
        system = platform.system()
        if system in ('Windows', 'Linux', 'Darwin'):
            return system
        return "Unsupported OS"


if __name__ == '__main__':
    folder = input("input folder:")
    print(DeviceUtils.get_wechat_wxid(folder))

# !/usr/bin/python3
# -*- coding:utf-8 -*-
"""
@author: JHC000abc@gmail.com
@file: utils_cmd.py
@time: 2025/7/8 21:53 
@desc: 

"""
import subprocess
from typing import Union, List, Callable, Optional
import threading


class CMDUtils:
    """

    """

    @staticmethod
    def run_await_results(cmd: Union[str, List[str]],
                          timeout: Optional[int] = None) -> str:
        """
        阻塞執(zhí)行命令并返回結(jié)果(自動(dòng)剝離首尾空格)

        :param cmd: 命令(字符串或列表形式)
        :param timeout: 超時(shí)時(shí)間(秒)
        :return: 命令輸出(stdout 或 stderr)
        :raises: subprocess.CalledProcessError 當(dāng)命令返回非零狀態(tài)碼時(shí)
        """
        result = subprocess.run(
            cmd,
            capture_output=True,
            text=True,
            check=True,
            shell=isinstance(cmd, str),
            timeout=timeout
        )
        return result.stdout.strip()

    @staticmethod
    def run_background(cmd: Union[str, List[str]],
                       **kwargs) -> subprocess.Popen:
        """
        后臺(tái)非阻塞執(zhí)行命令

        :param cmd: 命令(字符串或列表形式)
        :param kwargs: 傳遞給 subprocess.Popen 的額外參數(shù)
        :return: Popen 對(duì)象(可通過 returncode 屬性檢查狀態(tài))
        """
        return subprocess.Popen(
            cmd,
            stdout=subprocess.DEVNULL,
            stderr=subprocess.DEVNULL,
            shell=isinstance(cmd, str),
            **kwargs
        )

    @staticmethod
    def run_realtime_output(cmd: Union[str, List[str]],
                            output_handler: Callable[[str], None] = print,
                            **kwargs) -> subprocess.Popen:
        """
        實(shí)時(shí)輸出命令執(zhí)行結(jié)果(非阻塞)

        :param cmd: 命令(字符串或列表形式)
        :param output_handler: 自定義輸出處理函數(shù)(默認(rèn)打印到控制臺(tái))
        :param kwargs: 傳遞給 subprocess.Popen 的額外參數(shù)
        :return: Popen 對(duì)象
        """

        def _enqueue_output(pipe, handler):
            for line in iter(pipe.readline, ''):
                handler(line.strip())
            pipe.close()

        proc = subprocess.Popen(
            cmd,
            stdout=subprocess.PIPE,
            stderr=subprocess.STDOUT,
            text=True,
            shell=isinstance(cmd, str),
            **kwargs
        )

        # 啟動(dòng)獨(dú)立線程處理輸出
        threading.Thread(
            target=_enqueue_output,
            args=(proc.stdout, output_handler),
            daemon=True
        ).start()

        return proc

知識(shí)擴(kuò)展

Python實(shí)現(xiàn)微信導(dǎo)出群成員WXID

import tkinter as tk
from tkinter import ttk
from tkinter import messagebox
import threading
import requests
import json
import time
import base64
import io
try:
    from PIL import Image, ImageTk
    PIL_AVAILABLE = True
except ImportError:
    PIL_AVAILABLE = False
 
# 全局變量定義
token_id = None        # 接口Token
app_id = None          # 設(shè)備ID(appId)
logged_in = False      # 是否已登錄
account_nick = None    # 登錄賬戶昵稱(用于提示)
user_wxid = None       # 登錄賬戶的微信ID
 
# 初始化Tk窗口
root = tk.Tk()
root.title("Gewechat 工具")
root.geometry("800x600")
 
# 界面布局:登錄區(qū)、群列表區(qū)、批量加好友區(qū)、日志區(qū)
login_frame = ttk.Frame(root, padding=5)
group_frame = ttk.Frame(root, padding=5)
friend_frame = ttk.Frame(root, padding=5)
log_frame = ttk.Frame(root, padding=5)
 
login_frame.grid(row=0, column=0, sticky="NSW")
group_frame.grid(row=0, column=1, sticky="NS")
friend_frame.grid(row=0, column=2, sticky="NS")
log_frame.grid(row=1, column=0, columnspan=3, sticky="NSEW")
 
root.grid_columnconfigure(0, weight=1)
root.grid_columnconfigure(1, weight=1)
root.grid_columnconfigure(2, weight=1)
root.grid_rowconfigure(1, weight=1)
 
# 登錄區(qū)域
lbl_login_status = ttk.Label(login_frame, text="登錄狀態(tài):未登錄")
lbl_login_status.pack(pady=5)
qr_label = ttk.Label(login_frame, text="(請(qǐng)掃描二維碼登錄)", justify="center")
qr_label.pack()
 
# 群列表操作區(qū)域
group_buttons_frame = ttk.Frame(group_frame)
group_buttons_frame.pack(fill="x", pady=2)
btn_refresh_groups = ttk.Button(group_buttons_frame, text="獲取群列表")
btn_export_members = ttk.Button(group_buttons_frame, text="導(dǎo)出群成員")
btn_refresh_groups.pack(side="left", padx=2)
btn_export_members.pack(side="left", padx=2)
group_listbox = tk.Listbox(group_frame, height=15)
scrollbar_groups = ttk.Scrollbar(group_frame, orient="vertical", command=group_listbox.yview)
group_listbox.config(yscrollcommand=scrollbar_groups.set)
group_listbox.pack(side="left", fill="y", expand=True)
scrollbar_groups.pack(side="left", fill="y")
 
# 批量加好友區(qū)域
friend_label = ttk.Label(friend_frame, text="批量加好友(每行一個(gè)ID):")
friend_label.pack(anchor="w")
friend_text = tk.Text(friend_frame, width=30, height=10)
friend_text.pack(fill="both", expand=True)
btn_add_friends = ttk.Button(friend_frame, text="開始添加好友")
btn_add_friends.pack(pady=5)
 
# 日志輸出區(qū)域
log_label = ttk.Label(log_frame, text="日志輸出:")
log_label.pack(anchor="w")
log_text = tk.Text(log_frame, height=8)
log_text.pack(side="left", fill="both", expand=True)
log_scroll = ttk.Scrollbar(log_frame, orient="vertical", command=log_text.yview)
log_text.config(yscrollcommand=log_scroll.set, state="normal")
log_scroll.pack(side="right", fill="y")
 
def log_message(message: str):
    """在日志文本框追加消息(超過500字截?cái)啵?""
    truncated = message if len(message) <= 500 else message[:500] + "...(截?cái)?"
    def _append():
        log_text.insert(tk.END, truncated + "\n")
        log_text.see(tk.END)
    root.after(0, _append)
 
def save_credentials():
    """將當(dāng)前憑據(jù)保存到本地文件"""
    cred = {"appId": app_id, "tokenId": token_id}
    if user_wxid:
        cred["wxid"] = user_wxid
    try:
        with open("gewe_cred.json", "w", encoding="utf-8") as f:
            json.dump(cred, f, ensure_ascii=False, indent=4)
    except Exception as e:
        log_message(f"保存憑據(jù)失敗: {e}")
 
def load_credentials():
    """從本地文件加載上次保存的憑據(jù)"""
    global app_id, token_id
    try:
        with open("gewe_cred.json", "r", encoding="utf-8") as f:
            cred = json.load(f)
            app_id = cred.get("appId", "")
            token_id = cred.get("tokenId", "")
    except FileNotFoundError:
        app_id = ""
        token_id = ""
    except Exception as e:
        log_message(f"讀取憑據(jù)異常: {e}")
        app_id = ""
        token_id = ""
 
def http_post(endpoint: str, data: dict):
    """發(fā)送POST請(qǐng)求到Gewechat API并返回結(jié)果JSON(同時(shí)日志記錄請(qǐng)求和響應(yīng))"""
    url = base_url + endpoint
    try:
        payload_str = json.dumps(data, ensure_ascii=False)
    except Exception:
        payload_str = str(data)
    log_message(f"請(qǐng)求: POST {endpoint} {payload_str}")
    headers = {"Content-Type": "application/json"}
    if token_id:
        headers["X-GEWE-TOKEN"] = token_id
    try:
        resp = requests.post(url, json=data, headers=headers, timeout=10)
    except Exception as e:
        log_message(f"請(qǐng)求異常: {e}")
        return None
    resp_text = resp.text
    log_message(f"響應(yīng): {resp_text}")
    try:
        result = resp.json()
    except Exception:
        log_message("響應(yīng)非JSON格式或解析失敗")
        return None
    return result
 
def enable_ui_after_login():
    """登錄成功后,啟用各功能按鈕,并更新登錄狀態(tài)顯示"""
    btn_refresh_groups.config(state="normal")
    btn_export_members.config(state="normal")
    btn_add_friends.config(state="normal")
    status_text = "登錄成功"
    if account_nick:
        status_text = f"已登錄:{account_nick}"
    lbl_login_status.config(text=status_text)
    try:
        qr_label.config(image="", text="")  # 清除二維碼顯示
    except Exception:
        pass
 
def login_process():
    """登錄線程:檢查在線狀態(tài)或執(zhí)行掃碼登錄"""
    global logged_in, token_id, app_id, account_nick, user_wxid
    # 1. 嘗試使用已有token檢查是否在線
    if token_id:
        result = http_post("/login/checkOnline", {"appId": app_id})
        if result:
            ret = result.get("ret")
            data = result.get("data")
            if (ret == 200 or ret == 0) and data is True:
                # 當(dāng)前已在線
                logged_in = True
                log_message("當(dāng)前已在線,無需重復(fù)登錄")
                root.after(0, enable_ui_after_login)
                return
    # 2. 若不存在token或檢查結(jié)果離線,獲取新Token
    if not token_id or (result and result.get("ret") in [-1, 401, 404, 500] or result is None):
        log_message("獲取新的Token...")
        token_res = http_post("/tools/getTokenId", {})
        if token_res:
            if token_res.get("ret") in (200, 0):
                new_token = token_res.get("data") or token_res.get("token") or token_res.get("tokenId")
                if not new_token:
                    data_field = token_res.get("data")
                    if data_field and isinstance(data_field, dict):
                        new_token = data_field.get("token") or data_field.get("tokenId")
                if new_token:
                    token_id = new_token
                    log_message("Token獲取成功")
                else:
                    log_message("Token獲取失敗: 未返回token值")
            else:
                log_message(f"獲取Token失敗: {token_res.get('msg')}")
        else:
            log_message("獲取Token失敗: 無響應(yīng)")
        if not token_id:
            messagebox.showerror("登錄失敗", "無法獲取Token,登錄終止。")
            return
    # 3. 獲取登錄二維碼
    log_message("請(qǐng)求登錄二維碼...")
    req_app_id = app_id if app_id else ""
    payload = {"appId": req_app_id, "regionId": "320000"}
    qr_res = http_post("/login/getLoginQrCode", payload)
    if not qr_res or qr_res.get("ret") not in [200, 0]:
        log_message(f"獲取登錄二維碼失敗: {qr_res.get('msg') if qr_res else '無響應(yīng)'}")
        messagebox.showerror("登錄失敗", "獲取登錄二維碼失敗,請(qǐng)檢查服務(wù)器。")
        return
    qr_data = qr_res.get("data", {})
    new_app_id = qr_data.get("appId", "")
    if new_app_id:
        app_id = new_app_id
        log_message(f"使用設(shè)備ID: {app_id}")
    uuid = qr_data.get("uuid")
    if not uuid:
        qr_link = qr_data.get("qrData")
        if qr_link and "/x/" in qr_link:
            uuid = qr_link.split("/x/")[-1]
    qr_img_b64 = qr_data.get("qrImgBase64", "")
    if qr_img_b64:
        if qr_img_b64.startswith("data:image"):
            comma_index = qr_img_b64.find("base64,")
            if comma_index != -1:
                qr_img_b64 = qr_img_b64[comma_index+7:]
        try:
            img_data = base64.b64decode(qr_img_b64)
            if PIL_AVAILABLE:
                image = Image.open(io.BytesIO(img_data))
                tk_img = ImageTk.PhotoImage(image)
            else:
                tk_img = tk.PhotoImage(data=qr_img_b64)
            def show_qr():
                qr_label.config(image=tk_img)
                qr_label.image = tk_img
                lbl_login_status.config(text="請(qǐng)使用微信掃描二維碼登錄")
            root.after(0, show_qr)
        except Exception as e:
            log_message(f"二維碼顯示失敗: {e}")
    # 4. 輪詢檢查掃碼狀態(tài)
    log_message("等待掃碼確認(rèn)...")
    start_time = time.time()
    refresh_count = 0
    while not logged_in and refresh_count < 2:
        check_res = http_post("/login/checkLogin", {"appId": app_id, "uuid": uuid, "captchCode": ""})
        if check_res:
            ret = check_res.get("ret")
            data = check_res.get("data", {})
            if (ret == 200 or ret == 0) and data:
                status = data.get("status")
                if status == 0:
                    # 未掃碼
                    pass
                elif status == 1:
                    # 已掃碼,待確認(rèn)
                    nick = data.get("nickName")
                    if nick:
                        account_nick = nick
                        log_message(f"已掃碼,等待確認(rèn)登錄... (微信昵稱: {nick})")
                elif status == 2:
                    # 登錄成功
                    logged_in = True
                    login_info = data.get("loginInfo")
                    if login_info and isinstance(login_info, dict):
                        user_name = login_info.get("userName") or login_info.get("wxid")
                        if user_name:
                            log_message(f"登錄賬號(hào)ID: {user_name}")
                            user_wxid = user_name
                    if not account_nick:
                        account_nick = data.get("nickName") or (login_info.get("nickName") if login_info else None)
                    log_message("微信登錄成功")
                    break
            else:
                err_msg = check_res.get("msg") or (check_res.get("data", {}).get("msg") if isinstance(check_res.get("data"), dict) else "")
                log_message(f"登錄檢查失敗: {err_msg}")
        # 若超過約220秒未確認(rèn)且未登錄,嘗試刷新二維碼一次
        if time.time() - start_time > 220 and not logged_in and refresh_count < 1:
            log_message("二維碼已過期,正在獲取新的二維碼...")
            refresh_count += 1
            start_time = time.time()
            qr_res2 = http_post("/login/getLoginQrCode", {"appId": app_id, "regionId": "320000"})
            if qr_res2 and (qr_res2.get("ret") == 200 or qr_res2.get("ret") == 0):
                qr_data2 = qr_res2.get("data", {})
                uuid = qr_data2.get("uuid") or uuid
                qr_img_b64_new = qr_data2.get("qrImgBase64")
                if qr_img_b64_new:
                    if qr_img_b64_new.startswith("data:image"):
                        idx = qr_img_b64_new.find("base64,")
                        if idx != -1:
                            qr_img_b64_new = qr_img_b64_new[idx+7:]
                    try:
                        img_data = base64.b64decode(qr_img_b64_new)
                        if PIL_AVAILABLE:
                            image = Image.open(io.BytesIO(img_data))
                            tk_img2 = ImageTk.PhotoImage(image)
                        else:
                            tk_img2 = tk.PhotoImage(data=qr_img_b64_new)
                        def update_qr():
                            qr_label.config(image=tk_img2)
                            qr_label.image = tk_img2
                        root.after(0, update_qr)
                    except Exception as e:
                        log_message(f"新二維碼顯示失敗: {e}")
                log_message("請(qǐng)掃描新的二維碼")
            else:
                log_message("無法刷新二維碼,登錄失敗")
                break
        time.sleep(2)
    if not logged_in:
        log_message("登錄超時(shí)或失敗")
        messagebox.showwarning("登錄失敗", "二維碼超時(shí),請(qǐng)重新運(yùn)行程序重試。")
        return
    # 5. 登錄成功后,啟用功能并保存憑據(jù)
    root.after(0, enable_ui_after_login)
    save_credentials()
 
# 獲取群列表線程函數(shù)
def refresh_groups():
    global group_ids
    log_message("獲取通訊錄列表...")
    res = http_post("/contacts/fetchContactsList", {"appId": app_id})
    if not res or res.get("ret") not in [0, 200]:
        log_message("獲取通訊錄列表失敗")
        root.after(0, lambda: messagebox.showerror("錯(cuò)誤", "獲取群列表失敗"))
        return
    data = res.get("data", {})
    chatrooms = data.get("chatrooms", [])
    if not chatrooms:
        log_message("未獲取到任何群聊")
        root.after(0, lambda: messagebox.showinfo("結(jié)果", "通訊錄中沒有群聊"))
        return
    log_message(f"獲取到{len(chatrooms)}個(gè)群ID,正在獲取群名稱...")
    # 獲取群/好友簡(jiǎn)要信息以獲得群名稱
    info_res = http_post("/contacts/getContactInfo", {"appId": app_id, "userNames": chatrooms})
    group_name_list = []
    group_ids = []
    if info_res and (info_res.get("ret") == 0 or info_res.get("ret") == 200):
        info_data = info_res.get("data")
        if info_data:
            if isinstance(info_data, list):
                infos = info_data
            elif isinstance(info_data, dict) and info_data.get("contacts"):
                infos = info_data.get("contacts")
            elif isinstance(info_data, dict):
                infos = []
                for val in info_data.values():
                    if isinstance(val, dict):
                        infos.append(val)
            else:
                infos = []
            for info in infos:
                name = info.get("nickName") or info.get("userName")
                uid = info.get("userName") or info.get("wxid")
                if name:
                    group_name_list.append(name)
                    group_ids.append(uid)
    else:
        group_name_list = chatrooms
        group_ids = chatrooms
    def update_listbox():
        group_listbox.delete(0, tk.END)
        for name in group_name_list:
            group_listbox.insert(tk.END, name)
    root.after(0, update_listbox)
    log_message("群列表更新完成")
 
# 啟動(dòng)群成員導(dǎo)出線程(由按鈕觸發(fā))
def start_refresh_groups():
    threading.Thread(target=refresh_groups, daemon=True).start()
 
def start_export_members():
    # 主線程讀取選中項(xiàng)
    sel = group_listbox.curselection()
    if not sel:
        messagebox.showinfo("提示", "請(qǐng)先選擇一個(gè)群組")
        return
    index = sel[0]
    if index >= len(group_ids):
        messagebox.showerror("錯(cuò)誤", "群組選擇無效")
        return
    gid = group_ids[index]
    gname = group_listbox.get(index)
    def export_thread(group_id, group_name):
        log_message(f"正在導(dǎo)出群成員: {group_name} ({group_id})")
        res = http_post("/group/getChatroomMemberList", {"appId": app_id, "chatroomId": group_id})
        if not res or res.get("ret") not in [0, 200]:
            log_message("獲取群成員列表失敗")
            root.after(0, lambda: messagebox.showerror("錯(cuò)誤", f"獲取群成員失敗: {res.get('msg') if res else '無響應(yīng)'}"))
            return
        data = res.get("data", {})
        members = []
        if data:
            if "memberList" in data:
                members = data["memberList"]
            elif "members" in data and isinstance(data["members"], list) and data["members"] and isinstance(data["members"][0], dict):
                members = data["members"]
            elif isinstance(data, list):
                members = data
        if not members:
            log_message("群成員列表為空或解析失敗")
            root.after(0, lambda: messagebox.showinfo("提示", "未獲取到群成員信息"))
            return
        safe_name = "".join([c if c not in r'\/:*?"<>|' else "_" for c in group_name])
        if not safe_name:
            safe_name = group_id.replace("@chatroom", "")
        filename = f"{safe_name}_members.csv"
        try:
            with open(filename, "w", encoding="utf-8-sig") as f:
                f.write("微信ID,昵稱\n")
                for member in members:
                    wxid_val = member.get("wxid") or member.get("userName") or ""
                    nick_val = member.get("nickName") or ""
                    wxid_val = str(wxid_val).replace(",", " ")
                    nick_val = str(nick_val).replace(",", " ")
                    f.write(f"{wxid_val},{nick_val}\n")
            log_message(f"群成員已導(dǎo)出到文件: {filename}")
            root.after(0, lambda: messagebox.showinfo("導(dǎo)出完成", f"群成員列表已保存至 {filename}"))
        except Exception as e:
            log_message(f"導(dǎo)出文件寫入失敗: {e}")
            root.after(0, lambda: messagebox.showerror("錯(cuò)誤", f"導(dǎo)出文件失敗: {e}"))
    threading.Thread(target=export_thread, args=(gid, gname), daemon=True).start()
 
def start_add_friends():
    # 主線程獲取文本框內(nèi)容
    lines = friend_text.get("1.0", tk.END).strip().splitlines()
    ids_to_add = [line.strip() for line in lines if line.strip()]
    if not ids_to_add:
        messagebox.showinfo("提示", "請(qǐng)?jiān)谖谋究蛑休斎胍砑拥暮糜袸D,每行一個(gè)")
        return
    verify_message = "你好,我是通過群聊添加您為好友。"
    def add_thread(id_list):
        for wxid in id_list:
            log_message(f"搜索好友: {wxid}")
            search_res = http_post("/contacts/search", {"appId": app_id, "contactsInfo": wxid})
            if not search_res or search_res.get("ret") not in [0, 200]:
                log_message(f"搜索失敗: 無法找到 {wxid}")
                continue
            search_data = search_res.get("data", {})
            v3 = search_data.get("v3")
            v4 = search_data.get("v4")
            nick = search_data.get("nickName")
            if not v3 or not v4:
                log_message(f"無法添加 {wxid}: 未獲取到v3/v4")
                continue
            log_message(f"發(fā)送好友申請(qǐng)給 {wxid} (昵稱: {nick})")
            add_payload = {"appId": app_id, "v3": v3, "v4": v4, "scene": 3, "content": verify_message, "option": 2}
            add_res = http_post("/contacts/addContacts", add_payload)
            if add_res and (add_res.get("ret") == 0 or add_res.get("ret") == 200):
                log_message(f"已發(fā)送好友請(qǐng)求給 {wxid}")
            else:
                msg = add_res.get("msg") if add_res else "無響應(yīng)"
                log_message(f"添加好友失敗: {wxid} - {msg}")
        root.after(0, lambda: messagebox.showinfo("完成", "批量加好友操作完成,請(qǐng)查看日志獲取詳情。"))
    threading.Thread(target=add_thread, args=(ids_to_add,), daemon=True).start()
 
# 將按鈕點(diǎn)擊事件綁定到相應(yīng)線程啟動(dòng)函數(shù)
btn_refresh_groups.config(command=start_refresh_groups, state="disabled")
btn_export_members.config(command=start_export_members, state="disabled")
btn_add_friends.config(command=start_add_friends, state="disabled")
 
# 設(shè)置Gewechat服務(wù)的API地址(本地默認(rèn)端口2531)
base_url = "http://192.168.175.145:2531/v2/api"
group_ids = []  # 全局群ID列表(與列表框序號(hào)對(duì)應(yīng))
 
# 嘗試使用已保存的憑據(jù)自動(dòng)登錄,然后啟動(dòng)登錄線程
load_credentials()
threading.Thread(target=login_process, daemon=True).start()
root.mainloop()

到此這篇關(guān)于使用Python實(shí)現(xiàn)獲取本機(jī)當(dāng)前用戶登陸過的微信ID的文章就介紹到這了,更多相關(guān)Python獲取本機(jī)微信ID內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Pycharm設(shè)置utf-8自動(dòng)顯示方法

    Pycharm設(shè)置utf-8自動(dòng)顯示方法

    今天小編就為大家分享一篇Pycharm設(shè)置utf-8自動(dòng)顯示方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Python有序容器的 sort 方法詳解

    Python有序容器的 sort 方法詳解

    這篇文章主要介紹了Python有序容器的 sort 方法,容器.sort(key=選擇排序依據(jù)的函數(shù), reverse=True|False) 可以將有序容器進(jìn)行排序,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • PyTorch?Autograd的核心原理和功能深入探究

    PyTorch?Autograd的核心原理和功能深入探究

    本文深入探討了PyTorch中Autograd的核心原理和功能,從基本概念、Tensor與Autograd的交互,到計(jì)算圖的構(gòu)建和管理,再到反向傳播和梯度計(jì)算的細(xì)節(jié),最后涵蓋了Autograd的高級(jí)特性
    2024-01-01
  • Python私有pypi源注冊(cè)自定義依賴包Windows詳解

    Python私有pypi源注冊(cè)自定義依賴包Windows詳解

    這篇文章主要介紹了Python私有pypi源注冊(cè)自定義依賴包Windows,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Python使用cx_Oracle庫(kù)連接Oracle數(shù)據(jù)庫(kù)指南

    Python使用cx_Oracle庫(kù)連接Oracle數(shù)據(jù)庫(kù)指南

    這篇文章主要為大家介紹了Python使用cx_Oracle庫(kù)連接Oracle數(shù)據(jù)庫(kù)指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • 使用Python實(shí)現(xiàn)大學(xué)座位預(yù)約功能

    使用Python實(shí)現(xiàn)大學(xué)座位預(yù)約功能

    這篇文章主要介紹了如何用Python實(shí)現(xiàn)大學(xué)座位預(yù)約,今天這個(gè)教程教你如何搶到座位,有座位了還怕聽不到課嗎?感興趣的朋友一起看看吧
    2022-03-03
  • 使用PyCharm配合部署Python的Django框架的配置紀(jì)實(shí)

    使用PyCharm配合部署Python的Django框架的配置紀(jì)實(shí)

    這篇文章主要介紹了使用PyCharm配合部署Python的Django框架的配置紀(jì)實(shí),PyCharm是一款強(qiáng)大的Python的IDE,需要的朋友可以參考下
    2015-11-11
  • Python實(shí)現(xiàn)bilibili時(shí)間長(zhǎng)度查詢的示例代碼

    Python實(shí)現(xiàn)bilibili時(shí)間長(zhǎng)度查詢的示例代碼

    這篇文章主要介紹了Python實(shí)現(xiàn)bilibili時(shí)間長(zhǎng)度查詢的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • python中超簡(jiǎn)單的字符分割算法記錄(車牌識(shí)別、儀表識(shí)別等)

    python中超簡(jiǎn)單的字符分割算法記錄(車牌識(shí)別、儀表識(shí)別等)

    這篇文章主要給大家介紹了關(guān)于python中超簡(jiǎn)單的字符分割算法記錄,如車牌識(shí)別、儀表識(shí)別等,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-09-09
  • 如何利用python將一個(gè)py文件變成一個(gè)軟件詳解

    如何利用python將一個(gè)py文件變成一個(gè)軟件詳解

    在我們完成一個(gè)Python項(xiàng)目或一個(gè)程序時(shí),希望將Python的py文件打包成在Windows系統(tǒng)下直接可以運(yùn)行的exe程序,下面這篇文章主要給大家介紹了關(guān)于如何利用python將一個(gè)py文件變成一個(gè)軟件的相關(guān)資料,需要的朋友可以參考下
    2023-04-04

最新評(píng)論