当前位置: 首页 > article >正文

Python范例总结

一、基础功能

  1、操作符
  • and 拥有更高优先级,会先行运算。
  • 优先级顺序为 NOT、AND、OR。
  2、列表
    1)列表拼接
l1 = [1,2,3]
l2 = [4,5,6]

# 方法1
# l1 = l1 + l2

# 方法2
# l1[len(l1):len(l1)] = l2

# 方法3
l1.extend(l2)
print(l1)
   3、函数
    1)范例1
def greetPerson(*name):
    print('Hello', name)
  
greetPerson('Runoob', 'Google')
##结果为Hello ('Runoob', 'Google')
    2)范例2

  加了星号 * 的参数会以元组(tuple)的形式导入,存放所有未命名的变量参数。

x = True
def printLine(text):
    print(text, ' Runoob')
printLine('Python')
##Python  Runoob
    3)范例3
def Foo(x):
    if (x==1):
        return 1
    else:
        return x+Foo(x-1)

#n+n-1+1
print(Foo(100)) 
##结果是5050
   4、类
    1)私有字段/方法

  在Python中,属性和方法的访问权限只有两种:公开的和私有的。如果希望是私有的,在命名时可以用两个下划线作为开头。

  Python并没有从语法上严格保证私有属性或方法的私密性,它只是给私有属性和方法换了一个名字来“妨碍”对它们的访问,事实上如果你知道更换名字的规则仍然可以访问到它们。

  不建议将属性设置为私有的,因为这会导致子类无法访问。所以大多数Python程序员会遵循一种命名惯例就是让属性名以单下划线开头来表示属性是受保护的,本类之外的代码在访问这样的属性时应该要保持慎重。这种做法并不是语法上的规则,单下划线开头的属性和方法外界仍然是可以访问的,所以更多的时候它是一种暗示或隐喻

class JustCounter:
    __secretCount = 0  # 私有属性,前缀两个下划线
    publicCount = 0

    def count(self):
        self.__secretCount += 1  # 类内部调用私有属性
        self.publicCount += 1
        print(self.__secretCount)

    def __print1(self):  # 私有方法,前缀两个下划线
        print('This is a private method!')

    def print2(self):
        self.__print1()  # 类内部调用私有方法

counter = JustCounter()

print(counter.publicCount)

# print counter.__secretCount  # 报错,实例不能访问私有属性
print(counter._JustCounter__secretCount) # 可以通过( 对象名._类名__私有属性名 )访问私有属性
counter.count()
# counter.__print1()  # 报错,实例不能访问私有方法
counter._JustCounter__print1()  # 可以通过( 对象名._类名__私有方法名 )访问私有方法
counter.print2()

二、进阶功能

  1、函数
    1)偏函数
import functools
def func(a1,a2):
    print(a1,a2)


new_func = functools.partial(func, 666) ##666 传给第一个参数
new_func(999)
##结果 
666 999
    2)__开头的函数有很多

  当把面向对象中的所有__函数__实现时,对象做任何操作时,都会执行其中对应的方法

  举例1__add__

class Foo(object):
    def __init__(self, num):
        self.num =  num

    def __add__(self, other):
        data = self.num + other.num
        return Foo(data)


obj1 = Foo(1)
obj2 = Foo(2)

v = obj1.num + obj2.num

print(v)
## 结果是3
    3)链chain

  将每个列表的函数(功能)拼接到一个大的列表中,依次执行

from itertools import chain

def f1(x):
    return x + 1

func1_list = [f1,lambda x:x-1]

def f2(x):
    return x + 10

new_fun_list = chain([f2], func1_list)
for func in new_fun_list:
    print(func)

  列表也可以直接使用chain

from itertools import chain


l1 = [11,22,33]
l2 = [44,55,66]


new_list = chain(l1,l2)
for item in new_list:
    print(item)
     4)python命令行传参
  使用sys.argv传参

  sys模块是很常用的模块, 它封装了与python解释器相关的数据,例如sys.modules里面有已经加载了的所有模块信息,sys.path里面是PYTHONPATH的内容,而sys.argv则封装了传入的参数数据。

#!/usr/bin/python
# -*- coding: UTF-8 -*-
import sys
gpus = sys.argv[1]
#gpus = [int(gpus.split(','))]
batch_size = sys.argv[2]
print(gpus, type(gpus))
print(batch_size, type(batch_size))

  执行python argv_test.py 1,0,2 10

  使用argparse传参
#!/usr/bin/python
# -*- coding: UTF-8 -*-
import argparse
parser = argparse.ArgumentParser(description='manual to this script')
parser.add_argument('--gpus', type=str, default = None)
parser.add_argument('--batch-size', type=int, default=32)
args = parser.parse_args()
print(args.gpus, type(args.gpus))
print(args.batch_size, type(args.batch_size))

 执行:python argv_test.py --gpus=0,1,2 --batch-size=20

  2、类
    1)继承字典
class MyDict(dict):
    def __init__(self, *args, **kwargs):
        super(MyDict,self).__init__(*args, **kwargs)
        self['modify'] = True
        

obj = MyDict()
print(obj)
    2)打开/关闭实现:with方法
class SQLHelper(object):
    def open(self):
        pass

    def fetch(self, sql):
        pass

    def close(self):
        pass
### 方法1
# obj = SQLHelper()
# obj.open()
# obj.fetch('selcet * from table1')
# obj.close()


### 方法二
with SQLHelper() as obj: #自动调用类中的__enter__方法,obj就是__enter__返回值
    obj.fetch('selcet * from table1')
    # 当执行完毕后,自动调用类__exit__方法

  3、web框架的本质
    1)werkzeug
from werkzeug.wrappers import Request, Response

@Request.application
def hello(request):
    return Response('Hello World!')

if __name__ == '__main__':
    from werkzeug.serving import run_simple
    run_simple('127.0.0.1', 40000, hello)
 
    2)wsgi

  WSGI(Web Server Gateway Interface)是一种规范,它定义了使用python编写的web app与web server之间接口格式,实现web app与web server间的解耦。

  python标准库提供的独立WSGI服务器称为wsgiref。

from wsgiref.simple_server import make_server
 
 
def RunServer(environ, start_response):
    start_response('200 OK', [('Content-Type', 'text/html')])
    return [bytes('<h1>Hello, web!</h1>', encoding='utf-8'), ]
 
 
if __name__ == '__main__':
    httpd = make_server('', 8000, RunServer)
    print("Serving HTTP on port 8000...")
    httpd.serve_forever()


http://www.kler.cn/a/318680.html

相关文章:

  • 1.7 JS性能优化
  • 基于标签相关性的多标签学习
  • C++模板特化实战:在使用开源库boost::geometry::index::rtree时,用特化来让其支持自己的数据类型
  • 深入解析 OpenHarmony 构建系统-4-OHOSLoader类
  • 边缘计算在智能交通系统中的应用
  • 系统上线后发现bug,如何回退版本?已经产生的新业务数据怎么办?
  • 【计算机视觉】YoloV8-训练与测试教程
  • javascript是什么语言?它是干什么的?
  • Element UI在工程中使用方式
  • 79、Python之鸭子类型:没有听过鸭子类型?关键在于认知的转变
  • 网络安全-长亭雷池waf的sql绕过,安全狗绕过(5种绕过3+2)
  • 安科瑞Acrel-1000DP分布式光伏监控系统在鄂尔多斯市鄂托克旗巴音乌苏六保煤矿5MW分布式光伏项目中的应用
  • [linux][证书]证书导出公钥
  • MySQL记录存储过程执行的错误信息
  • 改进拖放PDF转换为图片在转换为TXT文件的程序
  • 浅谈C++之多线程实现
  • 口语训练材料
  • 力扣【283-移动零】【数组-C语言】
  • 微服务之服务保护
  • git checkout -b dev origin/dev
  • golang cmd.exec 执行命令后报错 No such file or directory
  • 最优化理论与自动驾驶(二-补充):求解算法(梯度下降法、牛顿法、高斯牛顿法以及LM法,C++代码)
  • Java-数据结构-排序(三) |ू・ω・` )
  • 【网络安全】密码学的新进展
  • Nginx 如何开启压缩
  • 伊犁云计算22-1 rhel8 dhcp 配置