Python中的类方法及属性总结举例,编写memcached启动脚本举例

1.类的属性总结
类属性,也是公有属性,

类的私有属性,

对象的共有属性,

对象的私有属性,

内置属性,

函数的局部变量,

全局变量,
#/usr/bin/env python
# -*- coding:utf-8 -*-
class MyClass(object):
        var1 = ‘类属性,类的公有属性 var1‘
        __var2 = ‘类的私有属性 __var2‘
        def func1(self):
            self.var3 = ‘对象的公有属性 var3‘
            self.__var4 = ‘对象的私有属性 __var4‘
            var5 = ‘函数的局部变量‘
mc = MyClass()
mc.func1()     #调用后才测打印出var3
print mc.var1
print mc._MyClass__var2
print mc.var3
mc1 = MyClass()
# mc1.func1()    #mc1没有调用方法
print mc1.var3

通过类访问:
    #/usr/bin/env python
    # -*- coding:utf-8 -*-
    # @Author :FengXiaoqing
    # @file   :__init__.py.py
    #
    var6 = ‘全局变量 ‘
    class MyClass(object):
        var1 = ‘类属性,类的公有属性 var1‘    ##定义在方法外
        __var2 = ‘类的私有属性 __var2‘
        def func1(self):
            self.var3 = ‘对象的公有属性 var3‘      ##定义在方法内
            self.__var4 = ‘对象的私有属性 __var4‘
            var5 = ‘函数的局部变量‘
        def func2(self):
            print self.var1
            print self.__var2
            print self.var3
            print self.__var4
            print self.var6
    mc = MyClass()
    mc.func1()
    mc.func2()
    print ‘*‘*50
    print mc.__dict__
    print MyClass.var1
    #print MyClass.__var2    #不测通过类访问
    print mc.var3       #对象的属性只能通过对象来访问
    #print MyClass.__var4
    print MyClass.__dict__

2.类的方法总结
公有方法

私有方法

类方法

静态方法

内置方法

class MyClass(object):
    name = ‘Test‘
    def func1(self):
        print self.name,
        print "我是公有方法."
        self.__func2() #func1间接调用了func2的私有方法
    def __func2(self):
        print self.name,
        print "我是私有方法."
    def classFun(self):
        print self.name,
        print "我是类方法."
    def staticFun(self):
        print s.name,
        print "我是静态方法."
mc = MyClass()
mc.func1()
调用类方法:用装饰器

    @classmethod
    def classFun(self):
        print self.name,
        print "我是类方法."
    def staticFun(self):
        print s.name,
        print "我是静态方法."
mc = MyClass()
mc.func1()
MyClass.classFun()

调用静态方法:

    @staticmethod
    def staticFun():
        print MyClass.name,
        print "我是静态方法."
mc = MyClass()
mc.func1()
MyClass.classFun()
MyClass.staticFun()

调用内置方法:

class MyClass(object):
    name = ‘Test‘
    def __init__(self):
        self.func1()
        self.__func2()
        self.classFun()
        self.staticFun()
    def func1(self):
        print self.name,
        print "我是公有方法."
    def __func2(self):
        print self.name,
        print "我是私有方法."
    @classmethod
    def classFun(self):
        print self.name,
        print "我是类方法."
    @staticmethod
    def staticFun():
        print MyClass.name,
        print "我是静态方法."
mc = MyClass()

3.Python编写memcached启动脚本
测试环境:CentOS 7

Python版本: 2.7
安装memcached:输入下面命令安装并用脚本测试

yum install -y memcached libmemcached libevent
测试方法:把脚本内容粘贴到rc.py文件中,shell下运行如果下命令:

python rc.py start
一、rc 脚本的start、stop、restart、status方法

#/usr/bin/env python
# -*- coding:utf-8 -*-
# [@Author](https://my.oschina.net/arthor) :FengXiaoqing
# [@file](https://my.oschina.net/u/726396)   :rc.py
import os
import sys
from subprocess import Popen,PIPE
class Process(object):
    ‘‘‘memcached rc script‘‘‘
    def __init__(self,name,program,args,workdir):
        self.name = name
        self.program = program
        self.args = args
        self.workdir = workdir

    def _init(self):
        ‘‘‘/var/tmp/memcached‘‘‘
        if not os.path.exists(self.workdir):
            os.mkdir(self.workdir)
            os.chdir(self.workdir)

    def _pidFile(self):
        ‘‘‘/var/tmp/memcached/memcached.pid‘‘‘
        return os.path.join(self.workdir,"%s.pid" % self.name)

    def _writhPid(self):
        if self.pid:
            with open(self._pidFile(),‘w‘) as fd:
                fd.write(str(self.pid))

    def start(self):
        pid = self._getPid()
        if pid:
            print "%s is already runnig..." % self.name
            sys.exit()
        self._init()
        cmd = self.program + ‘ ‘ + self.args
        p = Popen(cmd,stdout=PIPE,shell=True)
        self.pid = p.pid
        self._writhPid()
        print "%s start Sucessful.." % self.name

    def _getPid(self):
        p = Popen([‘pidof‘,self.name],stdout = PIPE)
        pid = p.stdout.read().strip()
        return pid

    def stop(self):
        pid = self._getPid()
        if pid:
            os.kill(int(pid),15)
            if os.path.exists(self._pidFile()):
                os.remove(self._pidFile())
            print ("%s is stopped .") % self.name

    def restart(self):
        self.stop()
        self.start()

    def status(self):
        pid = self._getPid()
        if pid:
            print "%s is already running..." % self.name
        else:
            print "%s is not running..." % self.name

    def _help(self):
        print ("Usage: %s {start|stop|status|restart}") % __file__

def main():
    name = ‘memcached‘
    prog = ‘/usr/bin/memcached‘
    args = ‘-u nobody -p 11211 -c 1024 -m 64‘
    wd = ‘/var/tmp/memcached‘
    pm = Process(name = name,
                 program=prog,
                 args=args,
                 workdir=wd)
    try:
        cmd = sys.argv[1]

    except IndexError,e:
        print ("Option  error")
        sys.exit()
    if cmd == ‘start‘:
        pm.start()
    elif cmd == ‘stop‘:
        pm.stop()
    elif cmd == ‘restart‘:
        pm.restart()
    elif cmd == ‘status‘:
        pm.status()
    else:
        pm._help()
if __name__ == ‘__main__‘:
    main()

原文地址:https://blog.51cto.com/fengyunshan911/2419795

时间: 2024-09-28 22:39:27

Python中的类方法及属性总结举例,编写memcached启动脚本举例的相关文章

python进阶三(面向对象编程基础)【3-4 python中定义类方法】

python中定义类方法 和属性类似,方法也分实例方法和类方法. 在class中定义的全部是实例方法,实例方法第一个参数 self 是实例本身. 要在class中定义类方法,需要这么写: 1 class Person(object): 2 count = 0 3 @classmethod 4 def how_many(cls): 5 return cls.count 6 def __init__(self, name): 7 self.name = name 8 Person.count = P

Python编写的memcached启动脚本

Python编写memcached启动脚本 一.rc 脚本的start.stop.restart.status方法 #/usr/bin/env python # -*- coding:utf-8 -*- # @time   :2018/1/12 19:11 # @Author :FengXiaoqing # @file   :rc.py import os import sys from subprocess import Popen,PIPE class Process(object):   

python中string模块各属性以及函数的用法

任何语言都离不开字符,那就会涉及对字符的操作,尤其是脚本语言更是频繁,不管是生产环境还是面试考验都要面对字符串的操作. python的字符串操作通过2部分的方法函数基本上就可以解决所有的字符串操作需求: python的字符串属性函数 python的string模块 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 字符串属性函数 系统版本:CentOS release 6.2 (Final)2.6.32

【开发者笔记】python中的类方法(@classmethod)和静态方法(@staticmethod)

在java.c#等高级语言中我们用static来定义静态方法和静态变量,那么在python中如何定义静态方法和静态变量呢. python提供了@classmethod和@staticmethod来定义静态方法,刚接触的时候不太明白,Stack Overflow提供了一个比较方便理解的解释,Stack Overflow回答. 但是看完还是不太理解,于是自己写了个实例: class stclass(): d=1 #对象方法 def imethod(self): print(self) print("

Python中的类方法、实例方法、静态方法

类方法 @classmethod 在python中使用较少,类方法传入的第一个参数是 cls,是类本身: 类方法可以通过类直接调用或者通过实例直接调用,但无论哪种调用方式,最左侧传入的参数一定是类本身. 通常情况下,类方法使用 @classmethod 装饰器来声明 实例方法 实例方法需要将类实例化后调用,如果使用类直接调用实例方法,需要显式的将实例作为参数传入:使用实例调用则不需要. 最左侧传入的参数 self,是实例本身. 静态方法 @staticmethod 指类中无需实例参与即可调用的方

Python - 利用python编写的memcached启动脚本

memcached作为缓存文件服务,默认是操作系统里面是可以直接yum -y install memcached进行安装的. /etc/init.d/memcached 是属于系统shell编写的管理脚本,下面这个脚本是python脚本编写出来的memcached管理脚本,和shell编写的脚本实现的效果一样. #!/usr/bin/python import sys import os from subprocess import Popen,PIPE class Process(object

Python 中 创建类方法为什么要加self

Python的类方法和普通的函数有一个明显的区别,在类的方法必须有一个额外的第一个参数(self),但在调用这个方法的时候不必为这个参数数值(显胜于隐的引发).在Python的类方法中这个特别的参数指代是对象本身.而按照Python的惯例,它用self来表示(也可那以用其他任何名称来代替,只是 规范和标准建议一致使用self) 注:self在Python里不是关键字,self代表当前对象的地址,self能避免非限定调用的全局变量.

Python静态方法、类方法、属性方法

静态方法 使用静态方法以后,相当于把下面的函数和类的关系截断了,它的作用相当于是类下面的一个独立函数,不会自动传入参数self. class people:..... @staticmethod def xxx(): pass 类方法 只能访问类变量,不能访问实例变量. @classmethod class dog: name = "小黑" def __init__(self,name): self.name = name @classmethod def hit(cls): prin

Python中 str类方法(1)

capitalize() 字符串首字母大写 1 str1="ni hao ma" 2 str2=str1.capitalize() 3 print(str2)#输出: Ni hao ma center(width, fillchar=None) 将字符串放在中间:在制定长度下,首尾以指定字符填充 str1="this" str2=str1.center(20,"*") print(str2) #输出:********this******** st