您的位置:

python可以自定义at(python可以自定义变量类型吗)

本文目录一览:

python如何定义新对象

Python可以自定义新的类,然后用这些类创建新对象。

class Fruit:

    def __init__(self, name):

        self.name = name

    def prntName(self):

        print self.name

这是一个简单的Python类的实现。

fruit = Fruit('apple')

fruit.prntName()

这样子,我们就创建了一个自定义的新的对象了。

python AT命令求助

我只在Windows下用过pyserial,和你用的模块略微有差别。

从code看,你用write方法发送字符以后,没有回车(发送 \n 到串口),或许是因为这个,“AT+CGMI”其实没有执行,所以也读不出结果。

python行名怎么自定义

1、cmd007 作为自定义命令名称

2、cmd007 hello --name=Lily 作为自定义功能1的名称hello打招呼,输出:Hi, Lily

3、cmd007 eat --food=fish 作为自定义功能2的名称food吃东西,输出:I like to eat fish

(一)目录结构如下:

cmd007 # 文件夹必须和自定义命令同名

│ __init__.py

│ __main__.py

(二)实现自定义命令和功能1

在__main__.py中

View Code

来到cmd007的上级目录下,调出命令行客户端,执行命名:

python cmd007

python cmd007 -V

python cmd007 hello --name=Lily --count=3

python cmd007 hello -n Lilei -c 2

分别输出:

提示:如果将这个python包cmd007打包发布,然后安装到python中去,那么每行命令就不用输入python关键字了。

(三)实现自定义命令、功能1、功能2

在__main__.py中增加代码

# 自定义功能2:eat

@cli.command(name="eat")

@click.option('-f', '--food', help="please input your like food")

@click.option('-a', '--and-you', help="ask echo other", default=False)

def hello_command(food, and_you):

print("I like to eat {0}".format(food))

if and_you in ['t', 'T', 'true', 'True', True, 1, "1"]:

print("And what is your favorite food ?")

 

完整版:

View Code

执行

python cmd007 eat -f fish --and-you=1

输出

延伸:

@click.option()中的参数详解:

每个参数解释如下:

name or flags - 选项字符串的名字或者列表,例如 foo 或者 -f, --foo。

action - 命令行遇到参数时的动作,默认值是 store。

store_const,表示赋值为const;

append,将遇到的值存储成列表,也就是如果参数重复则会保存多个值;

append_const,将参数规范中定义的一个值保存到一个列表;

count,存储遇到的次数;此外,也可以继承 argparse.Action 自定义参数解析;

nargs - 应该读取的命令行参数个数,可以是具体的数字,或者是?号,当不指定值时对于 Positional argument 使用 default,对于 Optional argument 使用 const;或者是 * 号,表示 0 或多个参数;或者是 + 号表示 1 或多个参数。

const - action 和 nargs 所需要的常量值。

default - 不指定参数时的默认值。

type - 命令行参数应该被转换成的类型。

choices - 参数可允许的值的一个容器。

required - 可选参数是否可以省略 (仅针对可选参数)。

help - 参数的帮助信息,当指定为 argparse.SUPPRESS 时表示不显示该参数的帮助信息.

metavar - 在 usage 说明中的参数名称,对于必选参数默认就是参数名称,对于可选参数默认是全大写的参数名称.

dest - 解析后的参数名称,默认情况下,对于可选参数选取最长的名称,中划线转换为下划线.

python自定义函数有哪些?

Python的自定义函数格式中规中矩,用def引导自定义函数名,用括号给出该函数的参数,在冒号后换行通过缩进确定函数体。在格式上和条件判断语句有些相似。

如果函数名和变量名冲突了,相当于重新赋值。而python解释是从上到下的,也就是说此时谁在下面谁占用这个变量名。剩下的那个就只能在内存中等待垃圾回收了。

自定义函数的参数:

按道理来说,即使Python不严格要求定义函数参数,但这方面的知识有助于理解自定义函数中参数操作的情况,还是应该说明一下的。

可以简单地理解为在定义函数时括号中声明的参数是我们在函数使用中会用到的参数,在调用函数时括号中的变量就是参加函数运算用到的变量,换个名字参数(用于定义)和变量(用于调用)就足以理解了。

python如何自定义异常?

8.5. 用户自定义异常

在程序中可以通过创建新的异常类型来命名自己的异常(Python 类的内容请参见 类 )。异常类通常应该直接或间接的从 Exception 类派生,例如:

class MyError(Exception):

... def __init__(self, value):

... self.value = value

... def __str__(self):

... return repr(self.value)

...

try:

... raise MyError(2*2)

... except MyError as e:

... print('My exception occurred, value:', e.value)

...

My exception occurred, value: 4

raise MyError('oops!')

Traceback (most recent call last):

File "

", line 1, in ?

__main__.MyError: 'oops!'

在这个例子中,Exception 默认的 __init__() 被覆盖。新的方式简单的创建 value 属性。这就替换了原来创建 args 属性的方式。

异常类中可以定义任何其它类中可以定义的东西,但是通常为了保持简单,只在其中加入几个属性信息,以供异常处理句柄提取。如果一个新创建的模块中需要抛出几种不同的错误时,一个通常的作法是为该模块定义一个异常基类,然后针对不同的错误类型派生出对应的异常子类:

class Error(Exception):

"""Base class for exceptions in this module."""

pass

class InputError(Error):

"""Exception raised for errors in the input.

Attributes:

expression -- input expression in which the error occurred

message -- explanation of the error

"""

def __init__(self, expression, message):

self.expression = expression

self.message = message

class TransitionError(Error):

"""Raised when an operation attempts a state transition that's not

allowed.

Attributes:

previous -- state at beginning of transition

next -- attempted new state

message -- explanation of why the specific transition is not allowed

"""

def __init__(self, previous, next, message):

self.previous = previous

self.next = next

self.message = message

与标准异常相似,大多数异常的命名都以 “Error” 结尾。

很多标准模块中都定义了自己的异常,用以报告在他们所定义的函数中可能发生的错误。

python获取给手机发送AT命令如何获取返回值?

安装一个pyseries包。 然后找一个AT标准的命令集。似乎有人封装好了。我以前见过。

然后剩下的事情就超 简单了。 测试通过就可以用。

好象以前是用这个做运维时,给运维人员发短信用的。这个功能十几年前就成熟了。现在都应该 有现成的python模块。