`

使用CMD模块,让脚本更舒服些

 
阅读更多

转自:蛇小狼

平时由于经常给测试人员调试一些东西,虽然写了一些脚本,感觉还是不方便。

python的cmd模块提供的更优雅的方式,很喜欢。

刚写了一些平时常用的测试代码:

 

# -*- coding:utf-8 -*-

import os, sys
from datetime import datetime
import cmd
import warnings


from django.conf import settings


def not_exit(func):
    def _func(*args, **kwargs):
        try:
            res = func(*args, **kwargs)
            return res
        except:
            print "there is a wrong in %s, please input 'help %s' to get help" %  (func.__name__, func.__name__[3:])
            return None
    return _func

class NBScript(cmd.Cmd):
    
    def __init__(self):
        cmd.Cmd.__init__(self)
        #设置命令提示符
        self.prompt = '> '
        #配置django环境
        pathname = os.path.dirname(sys.argv[0])
        sys.path.append(os.path.abspath(pathname))
        sys.path.append(os.path.normpath(os.path.join(os.path.abspath(pathname), '../')))
        os.environ['DJANGO_SETTINGS_MODULE'] = 'settings'

    #清用户cache
    def help_clear_cache(self):
        print "Usage:clear_cache [sns_id]"
        print "-- clear the user's cache"

    @not_exit
    def do_clear_cache(self, sns_id):
        from scripts.update_cache import clear_member_all_cache
        clear_member_all_cache(sns_id)

    #用户升级
    def help_user_level_up(self):
        print "Usage:user_level_up [sns_id] [level]"
        print "-- level up the user to the level"

    @not_exit
    def do_user_level_up(self, parms):
        from apps.members.cache import get_member_by_sns_id, get_or_create_almanac_info
        from apps.members.constants import EXP_LEVEL
        
        sns_id, level = parms.split()
        sns_id = int(sns_id)
        level = int(level)
        member = get_member_by_sns_id(sns_id)
        al_info = get_or_create_almanac_info(member.id)
        al_info.exp = EXP_LEVEL[level-1] + 1
        al_info.save()

    #增加用户珍珠
    def help_add_pearls(self):
        print "Usage:add_pearls [sns_id] [pearls]"
        print "-- add some pearls to the user"

    @not_exit
    def do_add_pearls(self, parms):
        from platforms.account.helper import add_account_pearls
        
        sns_id, pearls = parms.split()
        sns_id = int(sns_id)
        pearls = int(pearls)
        add_account_pearls('', '', sns_id, pearls, type='Test', money=0)

    #分鱼
    def help_add_fishes(self):
        print "Usage:add_fishes [sns_id] [fish1 fish2 ...]"
        print "-- add some fishes to the user"

    @not_exit
    def do_add_fishes(self, parms):
        from apps.members.cache import get_member_by_sns_id
        from apps.members.helper import new_a_member_fish
        from apps.products.cache import get_fish
        
        array = parms.split()
        sns_id = int(array[0])
        fish_ids = [int(i) for i in array[1:]]
        member = get_member_by_sns_id(sns_id)
        for fish_id in fish_ids:
            fish = get_fish(fish_id)
            new_a_member_fish(member, fish.id, update_almanac=True)

    #分贝壳
    def help_add_shells(self):
        print "Usage:add_shells [sns_id] [shells]"
        print "-- add some shells to the user"

    @not_exit
    def do_add_shells(self, parms):
        from apps.members.cache import get_member_by_sns_id
        
        sns_id, num = parms.split()
        sns_id = int(sns_id)
        num = int(num)
        member = get_member_by_sns_id(sns_id)
        member.shells += num
        member.save()

    #分鱼食
    def help_add_fish_food(self):
        print "Usage:add_fish_food [sns_id] [food_num]"
        print "-- add some food to the user"

    @not_exit
    def do_add_fish_food(self, parms):
        from apps.members.cache import get_member_by_sns_id
        
        sns_id, num = parms.split()
        sns_id = int(sns_id)
        num = int(num)
        member = get_member_by_sns_id(sns_id)
        member.fish_food += num
        member.save()

    #分鱼缸
    def help_add_fish_tanks(self):
        print "Usage:add_fish_food [sns_id] [tank1,tank2 ...]"
        print "-- add some tanks to the user"

    @not_exit
    def do_add_fish_tanks(self, parms):
        from apps.members.cache import get_member_by_sns_id
        from apps.members.helper import new_a_member_tank
        from apps.products.cache import get_fish_tank
        
        array = parms.split()
        sns_id = int(array[0])
        tank_ids = [int(i) for i in array[1:]]
        member = get_member_by_sns_id(sns_id)
        for tank_id in tank_ids:
            tank = get_fish_tank(tank_id)
            new_a_member_tank(member, tank.id)

    #分道具
    def help_add_items(self):
        print "Usage:add_items [sns_id] [itme1,item2 ...]"
        print "-- add some itmes to the user"

    @not_exit
    def do_add_items(self, parms):
        from apps.members.cache import get_member_by_sns_id
        from apps.members.helper import new_a_member_item
        from apps.products.cache import get_item
        
        array = parms.split()
        sns_id = int(array[0])
        item_ids = [int(i) for i in array[1:]]
        member = get_member_by_sns_id(sns_id)
        for item_id in item_ids:
            item = get_item(item_id)
            new_a_member_item(member, item.id)

    #刷任务
    def help_refresh_task(self):
        print "Usage:refresh_task [sns_id]"
        print "-- refresh user's task"

    @not_exit
    def do_refresh_task(self, sns_id):
        from apps.members.cache import get_member_by_sns_id
        
        sns_id = int(sns_id)
        member = get_member_by_sns_id(sns_id=sns_id)
        member.task_start_time = None
        member.save()

    #调合成等级
    def help_synthesis_level_up(self):
        print "Usage:synthesis_level_up [sns_id] [level]"
        print "-- level up user's synthesis level"

    @not_exit
    def do_synthesis_level_up(self, parms):
        from apps.members.cache import get_member_by_sns_id
        from apps.synthesis.cache import get_or_create_synth_info
        
        sns_id, lev = parms.split()
        sns_id = int(sns_id)
        lev = int(lev)
        member = get_member_by_sns_id(sns_id=sns_id)
        exp = int(sum([i**1.5*20 for i in range(1,lev+1)]))
        member = get_member_by_sns_id(sns_id)
        synth = get_or_create_synth_info(member.id)
        synth.synth_exp = exp
        synth.save()





    def help_quit(self):
        print "Usage:quit"

    def do_quit(self, line):
        exit()

    do_q = do_quit

if __name__ == "__main__":
    nb_script = NBScript()
    nb_script.cmdloop()
 

 

分享到:
评论

相关推荐

    易语言CMD模块易语言CMD模块

    通过熟练掌握易语言CMD模块,开发者可以利用易语言开发出更多功能强大的系统工具,例如批处理脚本、系统监控工具等。同时,这也是一种提升易语言程序功能和灵活性的有效途径。在实际开发中,结合易语言的基础语法和...

    cmd执行vbs脚本

    我个人喜欢研究cmd,后面无意中接触到vbs,就思考cmd能运行vbs么?---答案是可以的。经过研究发现,cmd可以执行vbs,但是还是需要生成vbs文件,执行完成后删除vbs文件

    后台执行CMD脚本,结果写入文件

    在IT行业中,后台执行CMD脚本是常见的自动化任务处理方式,尤其在系统管理和持续集成流程中扮演着重要角色。本文将深入探讨如何利用管道技术实现CMD脚本的后台执行,并将其结果写入文件,以便于日志记录和后续分析。...

    Python使用CMD模块更优雅的运行脚本

    本文实例讲述了Python使用CMD模块更优雅的运行脚本的方法。分享给大家供大家参考。具体分析如下: 平时由于经常给测试人员调试一些东西,虽然写了一些脚本,感觉还是不方便。 python的cmd模块提供的更优雅的方式,很...

    隐藏运行CMD命令脚本

    隐藏运行CMD命令脚本,可以使得CMD命令行在后台运行。

    易语言cmd.ec模块(易语言)

    CMD.ec模块的引入,让易语言程序可以执行系统命令、读取命令输出、管理文件和目录等,极大地扩展了易语言的应用范围。 易语言CMD.ec模块的主要功能包括: 1. **执行系统命令**:通过调用CMD模块,程序能够运行各种...

    bat+sqlcmd 批量运行脚本

    bat+sqlcmd 批量运行脚本 Hello,此BAT脚本可以帮助开发人员将某文件夹下所有SQL脚本按文件名依次在指定数据库中批量执行。不用忍受powershell invoke-sqlcmd 的笨重,在指运行时多一种选择。

    cmd脚本创建Oracle数据库

    cmd脚本创建Oracle数据库

    易语言CMD.rar

    总的来说,易语言CMD模块为易语言编程提供了更广阔的发挥空间,使开发者能够方便地利用CMD的强大功能,实现更多复杂的系统级任务。无论是初学者还是资深开发者,掌握这个模块都将极大地提升易语言程序的实用性和专业...

    WinCMD - Windows脚本命令解释程序

    WinCMD,全称为Windows Command Interpreter,是一款在Windows操作系统中用于执行批处理脚本和命令行操作的工具。它扩展了Windows内置的命令提示符(Command Prompt)的功能,提供了更多的实用命令和更友好的用户...

    封装后一键加域CMD批处理脚本

    在诸多可用的自动化解决方案中,CMD批处理脚本因其简单性和灵活性而被广泛使用。今天,我们将深入探讨一款特别的脚本——“封装后一键加域CMD批处理脚本”,以及它如何通过自动化流程改善计算机部署。 在企业网络...

    aspx脚本之cmd小命令

    ASP.Net执行cmd命令的实现代码,需要的朋友可以参考下:using System; using System.Collections; using System.Configuration; using System.Data; using System.Linq; using System.Web; using System.Web....

    将一些js库改写成符合cmd规范的模块

    本话题将深入探讨如何将现有的JavaScript库改写为符合CMD规范的模块,以便更好地在项目中利用和管理这些库。 CMD规范的核心思想是延迟执行和按需加载。它允许开发者在脚本中使用`define`函数来定义模块,并通过`...

    隐藏CMD黑窗(脚本)

    隐藏 CMD 黑窗口的脚本通常用于在运行批处理文件或其他命令行程序时,避免显示命令提示符窗口,这样可以让用户在后台执行脚本而不会干扰到其他任务。 该文件需配合BAT脚本使用,在.vbs中将路径指向BAT脚本并运行该...

    cmd脚本恢复系统文件

    7. **第三方工具**:虽然我们主要讨论的是`cmd`脚本,但有时也可以结合使用如`Recuva`这样的数据恢复工具,它们能够帮助找回已删除或丢失的文件。 在实际操作中,确保定期备份系统和重要数据至关重要。此外,遵循...

    linux 离线安装perl-IPC-Cmd

    如果一切顺利,`IPC::Cmd`模块应该已经成功安装在你的系统上,可以在Perl程序中使用了。 然而,离线安装可能还会遇到依赖问题。`IPC::Cmd`可能依赖于其他Perl模块,比如`Test::More`。在无网络环境下,你需要手动...

    cmd.ec下载模块

    cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块cmd.ec下载模块

    如何写批处理脚本(.dat/.cmd文件)

    这个例子展示了如何使用`pause`命令让用户更换磁盘后继续执行脚本。 ##### 6. Call 命令 `Call`命令用于调用另一个批处理文件或执行当前文件内的标签。这使得批处理脚本能够实现更加复杂的逻辑结构。 **语法:** ...

Global site tag (gtag.js) - Google Analytics