您的位置:首页 > 科技 > 能源 > 南昌网站建设制作与维护_手机游戏开发需要学什么_正规app推广_郑州官网关键词优化公司

南昌网站建设制作与维护_手机游戏开发需要学什么_正规app推广_郑州官网关键词优化公司

2024/12/23 6:15:04 来源:https://blog.csdn.net/happy_king_zi/article/details/142451470  浏览:    关键词:南昌网站建设制作与维护_手机游戏开发需要学什么_正规app推广_郑州官网关键词优化公司
南昌网站建设制作与维护_手机游戏开发需要学什么_正规app推广_郑州官网关键词优化公司

一、基础功能

  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 1else:return x+Foo(x-1)#n+n-1+1
print(Foo(100)) 
##结果是5050
   4、类
    1)私有字段/方法

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

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

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

class JustCounter:__secretCount = 0  # 私有属性,前缀两个下划线publicCount = 0def count(self):self.__secretCount += 1  # 类内部调用私有属性self.publicCount += 1print(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 =  numdef __add__(self, other):data = self.num + other.numreturn Foo(data)obj1 = Foo(1)
obj2 = Foo(2)v = obj1.num + obj2.numprint(v)
## 结果是3
    3)链chain

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

from itertools import chaindef f1(x):return x + 1func1_list = [f1,lambda x:x-1]def f2(x):return x + 10new_fun_list = chain([f2], func1_list)
for func in new_fun_list:print(func)

  列表也可以直接使用chain

from itertools import chainl1 = [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'] = Trueobj = MyDict()
print(obj)
    2)打开/关闭实现:with方法
class SQLHelper(object):def open(self):passdef fetch(self, sql):passdef 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_simplerun_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_serverdef 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()

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com