记录一段python代码 (修改数据库字符串)
admin
2023-05-26 05:41:21
0

 场景:由于开发恶心的账号登录设置,鉴于日本玩家用户习惯,刚开始以游客的身份登录游戏,若发生换包或者换设备,都需要从数据库重新更换账号ID,刚开始纯手工,其后py实现,封装为exe直接在dos里面执行,最好的方式改进当然是在web见面一键完成,现将代码跑路,作为记录。



# coding=utf-8
import pymysql
import traceback
import simplejson
import sys
# 交换
def exchange(connect_index, file_name):
    try:
        # 读取数据库配置
        fp = open("config.json")
        connect_info = simplejson.load(fp)["db_list"]
        fp.close()
        # 创建链接
        conn = pymysql.connect(host=str(connect_info[connect_index]["ip"]),
                               port=int(connect_info[connect_index]["port"]),
                               user=str(connect_info[connect_index]["user"]),
                               passwd=str(connect_info[connect_index]["passwd"]),
                               db=str(connect_info[connect_index]["db_name"]),
                               charset='utf8')
        # 获取光标
        cur = conn.cursor()
        # 读取交换列表
        fp = open(str(file_name))
        exchange_data = simplejson.load(fp)
        fp.close()
        # 开始交换
        for item in exchange_data:
            # 读取两个值的account_id
            player_datas = []
            for i in range(2):
                temp_data = {}
                cur.execute("select `id`, `account_id` from `character` where `"
                            + str(item["key"][i])
                            + "` = '"
                            + str(item["value"][i]) + "'")
                result = cur.fetchall()
                temp_data["id"] = result[0][0]
                temp_data["account_id"] = result[0][1]
                player_datas.append(temp_data)
            # 更改account_id以免发生冲突
            for player_data in player_datas:
                cur.execute("update `character` set `account_id` = '" + str(
                    player_data["account_id"]) + "_' where `id` = '" + str(player_data["id"]) + "'")
            conn.commit()
            # 交换
            temp_data = player_datas[0]["account_id"]
            player_datas[0]["account_id"] = player_datas[1]["account_id"]
            player_datas[1]["account_id"] = temp_data
            for player_data in player_datas:
                cur.execute("update `character` set `account_id` = '" + str(
                    player_data["account_id"]) + "' where `id` = '" + str(player_data["id"]) + "'")
            conn.commit()
        conn.close()
    except Exception:
        traceback.print_exc()
if __name__ == '__main__':
    try:
        if len(sys.argv) < 3:
            print "arg error"
            sys.exit(1)
        exchange(int(sys.argv[1]), sys.argv[2])
    except Exception:
        traceback.print_exc()



 部分json文件 还未整理,若有疑问请问博主,反正他也不会告诉你。

相关内容

热门资讯

雨夜坠河的皮卡,满车都是亲戚 作者 | 黄泽敏 实习生 | 黄思婷 编辑 | 向现肖逸(化名)没有等来奇迹。5月18日,肖逸告诉南...
赖清德抛0到18岁月发5000... 海峡导报综合报道 台湾地区领导人赖清德20日发表两周年就职演说,宣称台当局近日将提出所谓台湾人口对策...
与高市早苗保持距离,菲律宾总统... 菲律宾总统小马科斯近期在台湾问题上上演了一出极为滑稽前倨后恭变脸戏码。这位此前频频在台海和南海问题上...
是天“漏”了?气象部门解读广东... 5月15日以来,降雨强势来袭,覆盖湖北、海南、贵州、重庆、天津、湖南、河南、山东、广西、广东等十省区...
AI平台对“幻觉”现象的义务及... AI广泛使用,在信息收集分析、工作效率提升、思维能力拓展、视野开阔等方面给日常生产、生活不断带来便利...
北京无限迭代与腾讯云和中国电信... 近日,由深圳市工业和信息化局、深圳市人工智能产业办公室指导,深圳市人工智能行业协会与深圳会展中心管理...
蔡壁如宣布参选彰化县长,黄国昌... 日前,蔡壁如建置LINE群组,发布民调显示她超越国民党征召县长参选人魏平政。她也对外说她很少来彰化,...
郑丽文连续炮轰赖清德30分钟:... 据台湾《中时新闻网》报道,针对赖清德20日发表的“520”讲话及媒体提问,中国国民党主席郑丽文在中常...
盒马误将水仙当百合配送,致顾客... 近日,国家企业信用信息公示系统公示北京市朝阳区市场监督管理局行政处罚决定。针对今年1月盒马门店“误将...
最高法院拉偏架,共和党靠重划选... 近日,围绕国会选区重划问题,美国两党的斗争日趋激烈。4月,弗吉尼亚州以选民公投的方式通过了有利于民主...