返回顶部
首页 > 资讯 > 后端开发 > Python >记录一段python代码 (修改数据库字符串)
  • 386
分享到

记录一段python代码 (修改数据库字符串)

2024-04-02 19:04:59 386人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

 场景:由于开发恶心的账号登录设置,鉴于日本玩家用户习惯,刚开始以游客的身份登录游戏,若发生换包或者换设备,都需要从数据库重新更换账号ID,刚开始纯手工,其后py实现,封装为exe直接在dos里面

 场景:由于开发恶心的账号登录设置,鉴于日本玩家用户习惯,刚开始以游客的身份登录游戏,若发生换包或者换设备,都需要从数据库重新更换账号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文件 还未整理,若有疑问请问博主,反正他也不会告诉你。

--结束END--

本文标题: 记录一段python代码 (修改数据库字符串)

本文链接: https://lsjlt.com/news/40104.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 记录一段python代码 (修改数据库字符串)
     场景:由于开发恶心的账号登录设置,鉴于日本玩家用户习惯,刚开始以游客的身份登录游戏,若发生换包或者换设备,都需要从数据库重新更换账号ID,刚开始纯手工,其后py实现,封装为exe直接在dos里面...
    99+
    2024-04-02
  • mysql修改记录时update操作 字段=字段+字符串
    在有些场景下,我们需要对我们的varchar类型的字段做修改,而修改的结果为两个字段的拼接或者一个字段+字符串的拼接。 如下所示,我们希望将xx_role表中的name修改为name+id。 在mysql下,我们直...
    99+
    2022-05-25
    mysql 修改记录update
  • go 字符串修改的操作代码
    字符串和切片(string and slice) string底层就是一个byte的数组,因此,也可以进行切片操作。 package main import ("fmt") func...
    99+
    2024-04-02
  • Oracle修改数据库字符集
    1.(Window:)cmd下输入set ORACLE_SID=你想进入的数据库的那个sid(Linux:)切换到oracle用户:export  ORACLE_SID=你想进入的数据库的那个si...
    99+
    2024-04-02
  • mysql数据库的字符编码怎么修改
    mysql数据库字符编码可通过以下方法修改:修改数据库字符编码:alter database database_name character set new_character_set;...
    99+
    2024-05-22
    mysql 数据丢失
  • mysql数据库表和字段编码的修改方法
    本篇内容介绍了“mysql数据库表和字段编码的修改方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!用lo...
    99+
    2024-04-02
  • oracle数据库怎么修改字段里的数据
    要修改字段里的数据,可以使用UPDATE语句来实现。下面是修改字段数据的通用语法: UPDATE table_name SET co...
    99+
    2024-04-09
    oracle
  • php数据库怎么修改字段位置
    在PHP中,我们可以通过执行SQL语句来修改数据库的字段位置。下面就让我们来详细讨论如何使用PHP操作数据库进行字段位置修改。首先,我们需要连接到数据库。在连接到数据库之前,我们需要使用正确的主机名、用户名和密码等信息进行身份验证。一旦我们...
    99+
    2023-05-14
  • php数据库如何修改字段位置
    本文小编为大家详细介绍“php数据库如何修改字段位置”,内容详细,步骤清晰,细节处理妥当,希望这篇“php数据库如何修改字段位置”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。首先,我们需要连接到数据库。在连接到数...
    99+
    2023-07-06
  • pg数据库怎么修改字段类型
    要修改PostgreSQL数据库中的字段类型,可以使用ALTER TABLE语句。以下是一个示例: -- 修改字段类型为intege...
    99+
    2024-03-11
    pg数据库
  • oracle数据库怎么修改字段长度
    要修改Oracle数据库中的字段长度,可以使用ALTER TABLE语句。以下是详细步骤: 首先,连接到Oracle数据库并登录...
    99+
    2024-04-09
    oracle
  • navicat怎样修改数据库字符集
    这篇文章主要介绍navicat怎样修改数据库字符集,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!打开Navicart软件,打开连接,右击【数据库】—【编辑数据库】弹出编辑数据库窗口,...
    99+
    2024-04-02
  • 怎么修改oracle数据库字符集
    要修改Oracle数据库的字符集,你需要执行以下步骤:1. 运行 `sqlplus` 命令以登录到数据库。例如:`sqlplus /...
    99+
    2023-08-23
    oracle数据库
  • Oracle怎么修改数据库字符集
    要修改Oracle数据库的字符集,可以按照以下步骤进行操作: 首先备份数据库:在修改字符集之前,务必备份数据库以防止数据丢失。 ...
    99+
    2024-04-09
    Oracle 数据库
  • MySQL怎么修改数据库字符集
    要修改MySQL数据库的字符集,可以使用以下步骤: 登录到MySQL数据库服务器。 执行以下命令,将数据库字符集修改为指定的字符集...
    99+
    2024-04-09
    mysql 数据库
  • Python数据类型详解(一)字符串
    一.基本数据类型   整数:int   字符串:str(注:t等于一个tab键)   布尔值: bool   列表:list   列表用[]   元祖:tuple   元祖用()   字典:dict ...
    99+
    2022-06-04
    字符串 详解 数据类型
  • SQLServer数据库中怎么修改字段属性
    SQLServer数据库中怎么修改字段属性,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。  SQLServer数据库怎么修改字段属性  1...
    99+
    2024-04-02
  • oracle如何修改数据库表字段类型
    您可以使用ALTER TABLE语句来修改Oracle数据库表的字段类型。下面是一个例子:```sqlALTER TABLE 表名 ...
    99+
    2023-09-05
    oracle 数据库
  • 怎么修改数据库字段的默认值
    要修改数据库字段的默认值,可以使用ALTER TABLE语句。下面是一个示例: ALTER TABLE table_name ALT...
    99+
    2023-10-28
    数据库
  • Python数字/字符串补零操作实例代码
    有时候在使用 Python 的时候,想要对一个数字或者字符串进行补零操作,即把「1」变为一个八位数的「00000001」,这个时候可以使用一下方法来进行补零。 字符串补零: 可以使...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作