From 2b34924e06c0c36d77d9ccec4c4f10f1ebd16e84 Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期二, 16 九月 2025 19:03:17 +0800
Subject: [PATCH] 129 【战斗】战斗系统-服务端(NPC表加特长字段;)

---
 ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py |   17 ++++++++++++++---
 1 files changed, 14 insertions(+), 3 deletions(-)

diff --git a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py
index a7b8e5e..830f953 100644
--- a/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py
+++ b/ServerPython/ZoneServerGroup/map1_8G/MapServer/MapServerData/Script/IpyGameDataPY.py
@@ -84,6 +84,7 @@
                         ("DWORD", "SuckHPPer", 0),
                         ("DWORD", "SuckHPPerDef", 0),
                         ("dict", "SpecAttrInfo", 0),
+                        ("BYTE", "Specialty", 0),
                         ),
 
                 "NPCStronger":(
@@ -163,6 +164,7 @@
                         ("dict", "BatAttrDict", 0),
                         ("list", "FetterIDList", 0),
                         ("BYTE", "RecruitBySelf", 0),
+                        ("BYTE", "Specialty", 0),
                         ),
 
                 "HeroTalent":(
@@ -2642,7 +2644,8 @@
     def GetParryRateDef(self): return self.attrTuple[23] # 抗格挡概率 DWORD
     def GetSuckHPPer(self): return self.attrTuple[24] # 吸血比率 DWORD
     def GetSuckHPPerDef(self): return self.attrTuple[25] # 抗吸血比率 DWORD
-    def GetSpecAttrInfo(self): return self.attrTuple[26] # 特殊属性信息 {"属性ID":值, ...} dict
+    def GetSpecAttrInfo(self): return self.attrTuple[26] # 特殊属性信息 {"属性ID":值, ...} dict
+    def GetSpecialty(self): return self.attrTuple[27] #  特长 BYTE
 
 # NPC成长表
 class IPY_NPCStronger():
@@ -2736,7 +2739,8 @@
     def GetHPInheritPer(self): return self.attrTuple[11] # 生命继承 WORD
     def GetBatAttrDict(self): return self.attrTuple[12] # 其他战斗属性字典 {"属性ID":值, ...} dict
     def GetFetterIDList(self): return self.attrTuple[13] # 羁绊ID列表 list
-    def GetRecruitBySelf(self): return self.attrTuple[14] #  招募需要本体 BYTE
+    def GetRecruitBySelf(self): return self.attrTuple[14] #  招募需要本体 BYTE
+    def GetSpecialty(self): return self.attrTuple[15] #  武将特长 BYTE
 
 # 武将星级天赋表
 class IPY_HeroTalent():
@@ -6913,7 +6917,7 @@
     
     def __StrToList(self, strValue):
         setList = []
-        if ("[" in strValue and "]" in strValue) or ("(" in strValue and ")" in strValue):
+        if (strValue.startswith("[") and strValue.endswith("]")) or (strValue.startswith("(") and strValue.endswith(")")):
             setList = eval(strValue)
         elif strValue in ["0", "-", ""]:
             pass
@@ -6923,6 +6927,13 @@
             for value in strValue.split(ChConfig.Def_Str_Montant):
                 if value.isdigit():
                     value = int(value)
+                elif (value.startswith("[") and value.endswith("]")) or (value.startswith("(") and value.endswith(")")):
+                    value = eval(value)
+                else:
+                    try:
+                        value = float(value)
+                    except:
+                        pass
                 setList.append(value)
             if setList:
                 setList = tuple(setList)

--
Gitblit v1.8.0