From dd10f9563d8964cb80a3c2fd496cd08be549fd7c Mon Sep 17 00:00:00 2001
From: hxp <ale99527@vip.qq.com>
Date: 星期六, 14 三月 2020 17:34:11 +0800
Subject: [PATCH] 8401 【后端】BOSS复活修改(AC08封包增加每日最大可复活次数通知)

---
 ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py |   30 ++++++++++++++++++++++++++++++
 1 files changed, 30 insertions(+), 0 deletions(-)

diff --git a/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py b/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py
index 674e250..ae54f4e 100644
--- a/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py
+++ b/ServerPython/CoreServerGroup/GameServer/Script/GameWorld.py
@@ -544,6 +544,15 @@
     @param dateInfo: 运营活动表配置的日期信息, 如果是纯数字代表开服天
     @param openServerDay: 当前开服天
     '''
+    if not dateInfo:
+        curDateTime = datetime.datetime.today()
+        return "%d-%d-%d" % (curDateTime.year, curDateTime.month, curDateTime.day)
+    if dateInfo.startswith("W"):
+        curDateTime = datetime.datetime.today()
+        curWeekday = curDateTime.weekday() + 1
+        actionWeekday = int(dateInfo[1:])
+        actionDateTime = curDateTime + datetime.timedelta(days=(actionWeekday-curWeekday))
+        return "%d-%d-%d" % (actionDateTime.year, actionDateTime.month, actionDateTime.day)
     if dateInfo.startswith("Mix"):
         diffDay = PlayerDBGSEvent.GetDBGSTrig_ByKey(PlayerDBGSEvent.Def_MixServerDay) + 1
         actionServerDay = int(dateInfo[3:])
@@ -839,6 +848,14 @@
 def GetDatetimeBySubDays(diffDays):
     return datetime.datetime.today() - datetime.timedelta(days = diffDays)
 
+def GetDailyDateStr():
+    ## 获取日常日期 yyyy-MM-dd
+    curDate = GetServerTime()
+    if curDate.hour >= ShareDefine.Def_OnEventHour:
+        return "%d-%s-%s" % (curDate.year, curDate.month, curDate.day)
+    preDate = curDate - datetime.timedelta(days = -1) # 属于前一天
+    return "%s-%s-%s" % (preDate.year, preDate.month, preDate.day)
+
 def IsCrossServer():
     ## 是否跨服服务器
     return ToIntDef(ReadChConfig.GetPyMongoConfig("Merge", "IsMergeServer"), 0)
@@ -917,6 +934,19 @@
     
     return defValue
 
+## 从列表中产生物品,[[权重, object], ....]
+#  @param weightList 待选列表
+def GetResultByWeightList(weightList):
+    randList = []
+    weight = 0
+    for info in weightList:
+        weight += info[0]
+        randList.append([weight, info[1] if len(info) == 2 else info[1:]])
+    if not randList:
+        return
+    rate = random.randint(1, randList[-1][0])
+    return GetResultByRiseList(randList, rate)
+
 ## 根据字典key获取value值
 #  @return 
 def GetDictValueByKey(attrDict, findKey, defaultValue=None):

--
Gitblit v1.8.0