Skip to main content

a MUD Client written in Python

Project description

PyMUD - Python原生MUD客户端

2023-11-29 更新 V0.15c

帮助文件见北侠WIKI: https://www.pkuxkx.net/wiki/tools/pymud

1. 简介

北大侠客行Mud (www.pkuxkx.net),最好的中文Mud游戏!

PyMUD是我为了更好的玩北大侠客行,特意自行开发的MUD客户端。PyMUD具有以下特点:

  • 原生Python开发,除prompt-toolkit及其依赖库(wcwidth, pygment, pyperclip)外,不需要其他第三方库支持
  • 基于控制台的全屏UI界面设计,支持鼠标操作(Android上支持触摸屏操作)
  • 支持分屏显示,在数据快速滚动的时候,上半屏保持不动,以确保不错过信息
  • 解决了99%情况下,北大侠客行中文对不齐,也就是看不清字符画的问题(因为我没有走遍所有地方,不敢保证100%)
  • 真正的支持多session会话(也支持鼠标切换会话)
  • 原生支持多种服务器端编码方式,不论是GBK、BIG5、还是UTF-8
  • 支持NWAS、MTTS协商,支持GMCP、MSDP、MSSP协议
  • 一次脚本开发,多平台运行。只要能在该平台上运行python,就可以运行PyMUD客户端
  • 脚本所有语法均采用Python原生语法,因此你只要会用Python,就可以自己写脚本,免去了再去学习lua、熟悉各类APP的使用的难处
  • Python拥有极为强大的文字处理能力,用于处理文本的MUD最为合适
  • Python拥有极为丰富的第三方库,能支持的第三方库,就能在PyMud中支持
  • 我自己还在玩,所以本客户端会持续进行更新:)

2. 基本使用方法

打开PyMUD方法

在文件夹下,运行python pymud.py即可 现在支持鼠标和对话框操作了,当然,原有命令仍然基本支持

配置PyMUD参数

所有的配置都写在settings.py文件中,里面有注释,可以自行研究 Settings.session下面,可以自己把自己的角色信息加进去,会自动生成菜单,单击后可以自动登录,并且自动加载脚本

PyMUD命令

PyMUD目前使用纯命令行方式运行(现在支持鼠标、菜单、快捷键操作了),因此使用各类命令来完成,PyMud命令使用#开头,记住以下几个命令就可以了

#session

创建会话命令,1个会话就是1个角色的客户端,基本语法为(现在支持鼠标点击对话框创建了):

  • #session {name} {host} {port} {encoding}
  • name为会话的名称
  • host,port为服务器的地址和端口
  • encoding为编码方式,不指定时为utf-8
  • 例如:#session newstart mud.pkuxkx.net 8081
  • 创建一个名为newstart的会话,连接到mud.pkuxkx.net的8081端口,使用UTF8编码方式
  • 当存在多个会话时,可以直接使用#sessionname切换当前会话
  • 例如,#newstart可以直接将newstart会话切换为当前会话

#load

  • 加载配置文件,在会话链接成功后,可以使用#load {config}加载配置文件
  • 本版本附送了一个pkuxkx.py的配置文件,请大家自行参考
  • 加载pkuxkx.py配置文件的方法为,在session登录成功之后,使用#load pkuxkx即可

其他命令,就请各位自行摸索啦

3. 更新记录(从这一次开始)

2023-06-06

  • 当前版本:V0.05b
  • 修复了多个session时的bug
  • 增加了GMCP在session中的应用

2023-07-08

  • 当前版本:V0.10b
  • 重写整个界面
  • 增加了类zmud的操作命令习惯,如#wait, #message之类的,用法相同
  • 原0.05b脚本99%可以兼容,仅需将info\warning\error的调用由原来的app移动到session即可完美兼容

2023-08-08

  • 当前版本: V0.13b
  • 修复了部分BUG
  • 增加了状态窗口处理,通过Settings.py中"status_display"进行配置,0-不显示,1-显示在下方,2-显示在右侧
  • 状态窗口内容,通过在脚本中设置session.status_maker为对应的状态显示内容函数进行配置
  • 此处尝试了很久,目前都没有办法做到在运行后动态调整是否显示状态窗口和窗口位置,目前只能通过配置修改后重新运行实现
  • 一个示例的状态窗口内容反馈函数如下:
def status_window(self):

    lines = list()
    lines.append(f"角色: {self.session.getVariable('%charname')}({self.session.getVariable('%char')})")
    lines.append(f"门派: {self.session.getVariable('%menpai')}")
    lines.append(f"存款: {self.session.getVariable('%deposit')}")
    lines.append(f"潜能: {self.session.getVariable('pot')}")
    lines.append(f"经验: {self.session.getVariable('exp')}")
    lines.append(f"食物: {self.session.getVariable('food')}")
    lines.append(f"饮水: {self.session.getVariable('water')}")


    return "\n".join(lines)

2023-08-12

  • 当前版本: V0.14b
  • 修复部分BUG
  • 增加#clear/#cls命令,用于清除显示缓存

2023-10-16

  • 当前版本: V0.15b
  • 修复小BUG:当命令行输入内容括号或者引号不匹配时,会产生异常,原先会跳出到控制台界面报错,现改为在SESSION回话显示错误信息,并仍可以继续对该行数据进行处理
  • 增加两个小功能,在触发器处理时,可以使用#replace替换原显示行内容,或者使用#gag隐藏此行内容
  • 不使用SimpleTrigger时,可以使用session.handle_replace或者session.handle_gag进行处理
  • 增加了一个名为%raw的系统变量,表示当前行的原始信息(即包含ANSI字符的信息)

2023-11-29

  • 当前版本: V0.15c
  • 本版功能与V0.15b完全相同,仅修改了关于参数类型声明的语法,以适应低版本的Python。经测试,Python x64 3.7.9版可以正常运行。推测 >3.7 版均可正常运行。
  • 具体修改位置包括:
  • extra.py, line 275, SessionBufferControl 的 init 定义声明
  • extra.py, line 493, VSplitWindow 的 _copy_body 声明, line 534, _copy_line 声明
  • extra.py, line 969, MenuItem 的 init 声明
  • pymud.py, line 258, PyMudApp 的 create_world_menus 声明
  • session.py, line 297, Session 的 write 声明

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pymud-0.15.8.tar.gz (97.6 kB view hashes)

Uploaded Source

Built Distribution

pymud-0.15.8-py3-none-any.whl (83.8 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page