WeChatMsg/app/DataBase/msg.py

72 lines
2.0 KiB
Python
Raw Normal View History

2023-11-15 23:53:39 +08:00
import os.path
2023-11-16 23:16:38 +08:00
import re
2023-11-15 23:53:39 +08:00
import sqlite3
2023-11-16 23:16:38 +08:00
DB = []
cursor = []
msg_root_path = "./app/Database/Msg/"
2023-11-15 23:53:39 +08:00
# misc_path = './Msg/Misc.db'
2023-11-16 23:16:38 +08:00
if os.path.exists(msg_root_path):
for root, dirs, files in os.walk(msg_root_path):
for file in files:
if re.match('^MSG[0-9]+\.db$', file):
# print('ok', file)
msg_path = os.path.join(msg_root_path, file)
DB0 = sqlite3.connect(msg_path, check_same_thread=False)
# '''创建游标'''
cursor0 = DB0.cursor()
DB.append(DB0)
cursor.append(cursor0)
2023-11-16 22:39:59 +08:00
def init_database():
global DB
global cursor
if not DB:
2023-11-16 23:16:38 +08:00
if os.path.exists(msg_root_path):
for root, dirs, files in os.walk(msg_root_path):
for file in files:
# print(file)
if re.match('^MSG[0-9]+\.db$', file):
print('ok', file)
msg_path = os.path.join(msg_root_path, file)
DB0 = sqlite3.connect(msg_path, check_same_thread=False)
# '''创建游标'''
cursor0 = DB0.cursor()
DB.append(DB0)
cursor.append(cursor0)
2023-11-16 22:39:59 +08:00
def get_messages(username_):
sql = '''
select localId,TalkerId,Type,SubType,IsSender,CreateTime,Status,StrContent,strftime('%Y-%m-%d %H:%M:%S',CreateTime,'unixepoch','localtime') as StrTime
from MSG
where StrTalker=?
order by CreateTime
'''
2023-11-16 23:16:38 +08:00
result = []
for cur in cursor:
cur.execute(sql, [username_])
result_ = cur.fetchall()
# print(len(result))
result += result_
result.sort(key=lambda x: x[5])
return result
def close():
for db in DB:
db.close()
2023-11-16 22:39:59 +08:00
if __name__ == '__main__':
from pprint import pprint
2023-11-16 23:16:38 +08:00
msg_root_path = './Msg/'
2023-11-16 22:39:59 +08:00
init_database()
username = 'wxid_0o18ef858vnu22'
result = get_messages(username)
pprint(result)
pprint(len(result))