python常量类
㈠ 0x18是合法的python整型常量吗
0x18是合法的python整型常量。
Python 数字数据类型用于存储数值。
数字类型是不允许改变的,这就意味着如果改变数字数据类型得值,将重新分配内存空间。
以下实例在变量赋值时 Number 对象将被创建:
IntOne=1
IntTwo=2
也可以使用del语句删除一些数字对象的引用。
del IntOne
del IntTwo
当然了,也允许删除多个:
del IntOne,IntTwo
Python 支持三种不同的数值类型:
整型(Int) - 被称为是整数,是正或负整数,不带小数点。Python3 整型是没有限制大小的。也就是没有像java一样限制int类型的大小。
浮点型(float) - 浮点型由整数部分与小数部分组成,浮点型也可以使用科学计数法表示(2.5e2 = 2.5 x 102 = 250)。
复数( (complex)) - 复数由实数部分和虚数部分构成,可以用a + bj,或者complex(a,b)表示, 复数的实部a和虚部b都是浮点型。用表达式表示虚数也是可以的。
Python 数字类型转换
有时候,我们需要对数据内置的类型进行转换,数据类型的转换,你只需要将数据类型作为函数名即可。
int(x) 将x转换为一个整数。
float(x) 将x转换到一个浮点数。
complex(x) 将x转换到一个复数,实数部分为 x,虚数部分为 0。
complex(x, y) 将 x 和 y 转换到一个复数,实数部分为 x,虚数部分为 y。x 和 y 是数字表达式。
Python 可以使用 ** 操作来进行幂运算:
变量在使用前必须先"定义"(即赋予变量一个值),否则会出现错误:
不同类型的数混合运算时会将整数转换为浮点数(当然指的是不同的数,如果不是数的话就会出现错误了)
常用函数:
abs(x) x的绝对值
ceil() 返回数字的上入整数,如math.ceil(4.1) 返回 5
使用 (x>y)-(x
exp(x) 返回e的x次幂(ex),如math.exp(1) 返回2.718281828459045
fabs(x) 返回数字的绝对值,如math.fabs(-10) 返回10.0
floor(x) 返回数字的下舍整数,如math.floor(4.9)返回 4
log(x) 如math.log(math.e)返回1.0,math.log(100,10)返回2.0
log10(x) 返回以10为基数的x的对数,如math.log10(100)返回 2.0
max(x1,x2,,,,) 返回给定参数的最大值,参数可以为序列。
min(x1,x2) 返回给定参数的最小值,参数可以为序列。
mdf(x) 返回x的整数部分与小数部分,两部分的数值符号与x相同,整数部分以浮点型表示。
pow(x,y) x**y 运算后的值。
round(x,n) 返回浮点数x的四舍五入值,如给出n值,则代表舍入到小数点后的位数。
sqrt(x) 返回数字x的平方根。
随机数函数
随机数可以用于数学,游戏,安全等领域中,还经常被嵌入到算法中,用以提高算法效率,并提高程序的安全性。
choice(seq) 从序列的元素中随机挑选一个元素,比如random.choice(range(10)),从0到9中随机挑选一个整数。
randrange(start,stop,step) 从指定范围内,按指定基数递增的集合中获取一个随机数,基数缺省值为1
random() 随机生成下一个实数,它在[0,1)范围内。
seed(x) 改变随机数生成器的种子seed。如果你不了解其原理,你不必特别去设定, Python会帮你选择seed。
shuffle(seq) 将序列的所有元素随机排
unform(x,y) 随机生成下一个实数,它在[x,y]范围内。
数学常量:
i,e
㈡ python常量的值可以改变吗
首先先要理解常量与变量、赋值即定义
常量
1、python常量:内存中用于保存固定值的单元、在程序中、常量的值不能发生改变的
2、python常量命名规范:通常是以大写字母开头进行区分-Chy常量 chy变量
3、python常量的赋值:数字 字符串 布尔值 空值
4、举例:Aa=123、Ab='chy'、Ac=True和False、Ad=' ';
变量
1、python变量:占用内存中一块空间、用来存放变量的值(或地址)、存放的值是可以发生改变的
2、python变量命名规范:第1个字符必须是字母或下划线开始(_)不可用数字开头 不要用中文开头
3、第1个字符后边可以使用字母、数字、下划线进行组合 chy_0201=[1,2,3]
4、变量的赋值:
变量名=常量
a = 1
print(a)
变量名=其他变量名
a = 1
a = a + 1
print(a)
变量名=表达式
if a = 1:
print('ok')
变量名=函数(返回值)
a = 1
b = 2
c = a + b * 2
print(c)
5、python变量的命名是区分大小写的、小写是变量 大写是常量 chy与Chy是不同的
6、python中已经被使用的关键字不能用于声明变量
7、python中对变量进行赋值时、单引号和双引号是一样的 '' ""
8、赋值可以使用任意类型的数据、一个变量的类型不固定、变量值是有固定的类型的
9、查看数据类型使用type(变量名) asd='123' print(type(asd))
10、通过id(变量名)可以查看变量指向的内存地址
另外一般定义为常量就不会去重新赋值,如果要多次赋值,那就用变量。
首先声明:python没有真正意义上的常量!
但我们可以通过私有属性以及property属性相结合,zhuan自己设置出属于python的伪常量。
当然,这个常量其实也是可以改的,不过是比较麻烦,平常可以当作一个常量用
#1.先是用私有属性初始化一个量
class Man(object):
def __init__(self,age):
self.__age=age
#2.然后用property获取到
@property
def AGE(self):
return self.__age
#3.最后得到常量man.AGE,设置的常量,因property属性,所以调用不需要括号
man = Man(300)
print(man.AGE)
#4.现在验证,输入以下代码,结果为"AttributeError: can't set attribute"
man.AGE=33
#5.这就是python简单的设置伪常量!
希望对你有帮助!谢谢采纳!
㈢ python 定义常量类报错
你的python版本是py3.x吧?启竖散
raise加个纤蔽括号,用 raise self.ConstError("Can'悄氏t rebind const(%s)"%name)
㈣ Python其实很简单 第五章 基本数据类型
编程的目的就是为了处理信息,信息则是由各种不同类型的数据表示的,对数据的进一步处理也会使信息更加丰富和有效。
5.1变量
前面已经提到过“变量”这属语,下面再进一步解释一下。
在程序运行时,必须把数据导入计算机的存储单元中,但存储单元的命名是用二进制数表示的,晦涩难懂。为了方便起见,可以给存储单元起上一个通俗易懂的名字,即 变量名 。
变量的生命周期和程序的运行周期是相同的,一个程序运行解释,所占用的存储空间也就随之释放,用变量名表示的数据所占用的这个存储单元也就空闲了。
变量名的命名规则:
由字母、数字、下划线构成,必须由字母开头。
不能包含-、*、?、#、、;、/、、@、%、$、空格等特殊字符。
最好使用有含义的英文单词或汉语拼音。
最好采用小写字母。
不能使用保留字(已被Python语言系统本身赋予特定意义的单词)。Python的保留字如下表所示。
Python保留字列表
Python是区分大小写的,虽然可以将一个英文单词通过字母大小写不同而作为不同变量的变量名,但从程序可读性的角度看,的确不可取。
Python是一种动态类型的语言,变量的类型由变量的值决定。换而言之,给变量赋何种类型的值,变量就是该值的类型。给变量赋值可以通过赋值号(=)来实现。如:
>>> myvar=100
>>> type(myvar)
>>> myvar='tom'
>>> type(myvar)
在这个例子中,变量myvar首先赋值为100,显而易见,100是个整数,通过type()这个函数检测,变量myvar的类型为整数类型(int);接下来变量myvar赋值为‘tom’,通过type()这个函数检测,变量myvar的类型改变为字符串类型(str)。
不仅可以给一个变量赋值为常量,也可以赋值为另一个变量。如:
>>> a=100
>>> b=a
>>> b
100
在这个例子中,“b=a”的实际意义是,变量b和变量a指向同一个存储单元,既然是同一个存储单元,变量b和变量a本质上就是完全相同的,这就好比一个人除了本名之外,还有其他的名字,如笔名、昵称、乳名等等,虽然本质一样,但是可以在不同场合使用。
5.2关于Python的常量问题
在大多数语言中都有常量这个概念,但是Python却没有。其实仔细想想也好像没有设置常量的必要,只要一个变量的值不发生变化,即不给变量重新赋值,它的值当然不会变化,它便是个常量。
5.3基本数据类型
5.3.1整数型和浮点数
整数型(integer),可以是正整数、负整数和0,可以是十进制、八进制、二进制等。
浮点数(float),由整数部分和小数部分组成,主要用于处理包括小数的数。浮点数也可以用科学计数法表示。
5.3.2 字符串类型
字符串类型是由一系列的字母或者其他符号组成的数据序列,通常用单引号、双引号或三引号括起来。
用单引号和双引号括起来的字符串只能放在同一行,用三引号括起来的字符串可以分布在连续多行上。如:
name='我的名字叫王小明'
old="今年6岁"
introce='''我想说: 我是中国娃
爱讲普通话
要学习写标准的汉字'''
print(name)
print(old)
print(introce)
运行结果为:我的名字叫王小明
今年6岁
我想说: 我是中国娃
爱讲普通话
要学习写标准的汉字
不管是哪一种引号形式,括起来的部分是一个整体,包括空格和换行符都属于字符串的一部分。
为了保证特殊的输出效果,Python中的字符串支持转义字符,可使用反斜杠“”对一些特殊字符进行转义。常用的转义字符如下:
续行符
换行符
空
水平制表符
” 双引号
’ 单引号
一个反斜杠
f 换页
其中,续行符(“”)用于当一个字符串在一行写不下时用续行符进行连接,但通常更多的采用小括号“()”即可。
如:
第一种方法采用续行符(“”):
>>> str="A thousand wishes, a thousand plans and
a thousand resolutions are better than one action!"
>>> print(str)
A thousand wishes, a thousand plans and a thousand resolutions are better than one action!
第二种方法采用小括号():
>>> str=("A thousand wishes, a thousand plans and "
"a thousand resolutions are better than one action!")
>>> print(str)
A thousand wishes, a thousand plans and a thousand resolutions are better than one action!
下面举例说明换行符(“ ”)的用法:
>>> str=" 登鹳雀楼 白日依山尽, 黄河入海流。 欲穷千里目, 更上一层楼。 "
>>> print(str)
登鹳雀楼
白日依山尽,
黄河入海流。
欲穷千里目,
更上一层楼。
下面举例说明使用转义字符输出双引号(“)的方法:
>>> str="王之涣的诗《登鹳雀楼》中这样写道:" 白日依山尽,黄河入海流。欲穷千里目,更上一层楼。""
>>> print(str)
王之涣的诗《登鹳雀楼》中这样写道:" 白日依山尽,黄河入海流。欲穷千里目,更上一层楼。"
>>>
5.3.3布尔类型
布尔类型用来表示逻辑值,所谓逻辑判断的结果,不外乎“真”或“假”两种情况。在Python中“真”用True表示,“假”用False表示。如果布尔类型的变量参与算数运算,则True被当作1,False被当作0。
如:
>>> result=True
>>> print(result)
True
>>> print(result+1)
2
>>> result=False
>>> print(result)
False
>>> print(result+1)
1
5.3.4类型强制转换
Python是一种弱数据类型语言,可以通过给变量重新赋值的方法改变数据类型。但有时为了强制改变数据类型,就要使用类型转换函数来改变。
譬如,为了从键盘读入成绩的数据,可以用float()函数将input()语句读入的字符串转换为浮点数,再赋值给变量score。
>>> score=input("请输入您的成绩:")
请输入您的成绩:96.5 (从键盘输入96.5)
为了计算成绩比及格线高了多少分,使用下面的命令,发现出现了错误提示如下:
>>> score-60
Traceback (most recent call last):
File " ", line 1, in
score-60
TypeError: unsupported operand type(s) for -: 'str' and 'int'
这是属于类型错误,原因是从键盘读入的成绩值(96.5)并非数值类型,不能参与算数运算。用type()函数可以进一步查询变量score的数据类型。
>>> type(score)
使用float()函数进行强制转换后,就可以解决上述问题:
>>> score=float(input("请输入您的成绩:"))
请输入您的成绩:96.5
>>> score=float(score)
>>> type(score)
>>> score-60
36.5
下表列举了一些常用的类型转换函数:
㈤ Python中所有变量和常量都是有所属类型的吗
在 Python 中,数据类型是动态的,这意味着变量的数据类型可以在运行时改变。因此,在 Python 中,不是所有变量和常量都有所属类型。
Python中的变量不需要事先声明变量类型,可以直接使用等号进行赋值。
例如:a = 42b = "Hello World"
变量 a 是一个整数类型的变量,变量 b 是一个字符串类型的变量。
常量的概念与变量不同,常量指被程序预定义的值,在 Python 中常常使用常量来代替某些常用的固定值或者比较难计算的值。Python没饥袭有直接定义常量的关键字,可以通过大写的方式来烂伍兄表示常量。
例如:PI = 3.14
在 Python 中,这个 PI 变量是一个常量,一橘森般情况下值不会发生改变。但事实上,Python并没有对这个变量做出保护,还是可以通过程序去改变它的值。
总之,在 Python 中,变量和常量是没有被严格区分的,它们都是可以被赋予不同类型的值的。但是一些比较常用的值可以通过定义为常量来表明其意义和作用。
㈥ 在python中怎么定义常量
通常是在py 函数上面,import下面
大写字母作为常量名。
比如:
importxxx
WORKER_NUMBER=100
defhehe():
......
㈦ 如何定义和使用Python中常量
一、访问字典的元素使用dobj.get(key, somethingelse),如果对应key值元素不存在,你将会得到somethingelse值,例如“not found” 不要使用dobj[key],因为如果key对应元素不存在,则会产生KeyError异常,这样必须使用try...except来封装 二、名字空间中的属性可以通过字典__dict__来访问 __setattr__负责处理属性赋值,其内进行赋值时要使用self.__dict__[attr] = value以防止递归 三、sys.moles是一个字典,它包含了从Python开始运行起,被导入的所有模块。键字就是模块名,键值就是模块对象。请注意除了你的程序导入的模块外还有其它模块。Python在启动时预先装入了一些模块,如果你在一个Python IDE环境下,sys.moles包含了你在IDE中运行的所有程序所导入的所有模块定义class _const(object): class ConstError(TypeError): pass def __setattr__(self, name, value): if self.__dict__.has_key(name): raise self.ConstError, "Cant rebind const(%s)" % name self.__dict__[name] = value def __delattr__(self, name): if name in self.__dict__: raise self.ConstError, "Cant unbind const(%s)" % name raise NameError, nameimport syssys.moles[__name__] = _const()使用import const const.value = somevalue const.value = newvalue # 产生异常const.ConstError技巧1、使用__setattr__来控制重新绑定 2、sys.moles[name]得到的是模块对象,通过模块对象可以访问其模块属性;而Python不会进行严格的类型检测,所以直接将一个 _const类对象加入sys.moles字典,而__name__的值为对应模块const的名字const,通过 sys.moles[__name__] = _const()用类对象替换模块对象,将对应的名字空间加以限制,当使用import const时,会发生sys.moles[const] = _const();而访问const.attrvalue时会发生sys.moles[const].attrvalue,即 _const().attrvalue
㈧ python选择结构分为哪几类每一类的语法格式怎么书写
分三类:单分支,双分支,多分支。
输出
用print()在括号中加上字符串,就可以向屏幕上输出指定的文字。比如输出'hello, world',用代码实现如下:
>>> print('hello, world')
print()函数也可以接受多个字符串,用逗号“,”隔开,就可以连成一串输出:
>>> print('The quick brown fox', 'jumps over', 'the lazy dog')
The quick brown fox jumps over the lazy dog
print()会依次打印每个字符串,遇到逗号“,”会输出一个空格
print()也可以打印整数,或者计算结果:
>>> print(300)
300
>>> print(100 + 200)
300
因此,我们可以把计算100 + 200的结果打印得更漂亮一点:
>>> print('100 + 200 =', 100 + 200)
100 + 200 = 300
输入
Python提供了一个input(),可以让用户输入字符串,并存放到一个变量里。比如输入用户的名字:
>>> name = input()
Michael
当你输入name = input()并按下回车后,Python交互式命令行就在等待你的输入了。这时,你可以输入任意字符,然后按回车后完成输入。
输入完成后,不会有任何提示,Python交互式命令行又回到>>>状态了。那我们刚才输入的内容到哪去了?答案是存放到name变量里了。可以直接输入name查看变量内容:
>>> name
'Michael'
结合输入输出
name = input()
print('hello,', name)
数据类型
整数
Python可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样,例如:1,100,-8080,0,等等。
计算机由于使用二进制,所以,有时候用十六进制表示整数比较方便,十六进制用0x前缀和0-9,a-f表示,例如:0xff00,0xa5b4c3d2,等等。
浮点数
浮点数也就是小数,之所以称为浮点数,是因为按照科学记数法表示时,一个浮点数的小数点位置是可变的,比如,1.23x109和12.3x108是完全相等的。浮点数可以用数学写法,如1.23,3.14,-9.01,等等。但是对于很大或很小的浮点数,就必须用科学计数法表示,把10用e替代,1.23x109就是1.23e9,或者12.3e8,0.000012可以写成1.2e-5,等等。
整数和浮点数在计算机内部存储的方式是不同的,整数运算永远是精确的(除法难道也是精确的?是的!),而浮点数运算则可能会有四舍五入的误差。
字符串
字符串是以单引号'或双引号"括起来的任意文本,比如'abc',"xyz"等等。请注意,''或""本身只是一种表示方式,不是字符串的一部分,因此,字符串'abc'只有a,b,c这3个字符。如果'本身也是一个字符,那就可以用""括起来,比如"I'm OK"包含的字符是I,',m,空格,O,K这6个字符。
如果字符串内部既包含'又包含"怎么办?可以用转义字符\来标识,比如:
'I\'m \"OK\"!'
表示的字符串内容是:
I'm "OK"!
转义字符\可以转义很多字符,比如\n表示换行,\t表示制表符,字符\本身也要转义,所以\\表示的字符就是\,可以在Python的交互式命令行用print()打印字符串看看:
>>> print('I\'m ok.')
I'm ok.
>>> print('I\'m learning\nPython.')
I'm learning
Python.
>>> print('\\\n\\')
\
\
如果字符串里面有很多字符都需要转义,就需要加很多\,为了简化,Python还允许用r''表示''内部的字符串默认不转义,可以自己试试:
>>> print('\\\t\\')
\ \
>>> print(r'\\\t\\')
\\\t\\
如果字符串内部有很多换行,用\n写在一行里不好阅读,为了简化,Python允许用'''...'''的格式表示多行内容,可以自己试试:
>>> print('''line1
... line2
... line3''')
line1
line2
line3
上面是在交互式命令行内输入,注意在输入多行内容时,提示符由>>>变为...,提示你可以接着上一行输入,注意...是提示符,不是代码的一部分:
┌────────────────────────────────────────────────────────┐
│Command Prompt - python _ □ x │
├────────────────────────────────────────────────────────┤
│>>> print('''line1 │
│... line2 │
│... line3''') │
│line1 │
│line2 │
│line3 │
│ │
│>>> _ │
│ │
│ │
│ │
└────────────────────────────────────────────────────────┘
当输入完结束符```和括号)后,执行该语句并打印结果。
如果写成程序并存为.py文件,就是:
print('''line1
line2
line3''')
多行字符串'''...'''还可以在前面加上r使用
布尔值
布尔值和布尔代数的表示完全一致,一个布尔值只有True、False两种值,要么是True,要么是False,在Python中,可以直接用True、False表示布尔值(请注意大小写),也可以通过布尔运算计算出来:
>>> True
True
not运算是非运算,它是一个单目运算符,把True变成False,False变成True:
>>> not True
False
空值
空值是Python里一个特殊的值,用None表示。None不能理解为0,因为0是有意义的,而None是一个特殊的空值。
此外,Python还提供了列表、字典等多种数据类型,还允许创建自定义数据类型,我们后面会继续讲到。
变量
变量的概念基本上和初中代数的方程变量是一致的,只是在计算机程序中,变量不仅可以是数字,还可以是任意数据类型。
变量在程序中就是用一个变量名表示了,变量名必须是大小写英文、数字和_的组合,且不能用数字开头,比如:
a = 1
变量a是一个整数。
t_007 = 'T007'
变量t_007是一个字符串。
Answer = True
变量Answer是一个布尔值True。
在Python中,等号=是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量
这种变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言。静态语言在定义变量时必须指定变量类型,如果赋值的时候类型不匹配,就会报错。
最后,理解变量在计算机内存中的表示也非常重要。当我们写:
a = 'ABC'
时,Python解释器干了两件事情:
在内存中创建了一个'ABC'的字符串;
在内存中创建了一个名为a的变量,并把它指向'ABC'。
也可以把一个变量a赋值给另一个变量b,这个操作实际上是把变量b指向变量a所指向的数据
常量
所谓常量就是不能变的变量,比如常用的数学常数π就是一个常量。在Python中,通常用全部大写的变量名表示常量:
PI = 3.14159265359
但事实上PI仍然是一个变量,Python根本没有任何机制保证PI不会被改变,所以,用全部大写的变量名表示常量只是一个习惯上的用法,如果你一定要改变变量PI的值,也没人能拦住你。
最后解释一下整数的除法为什么也是精确的。在Python中,有两种除法,一种除法是/:
>>> 10 / 3
3.3333333333333335
/除法计算结果是浮点数,即使是两个整数恰好整除,结果也是浮点数:
>>> 9 / 3
3.0
还有一种除法是//,称为地板除,两个整数的除法仍然是整数:
>>> 10 // 3
3
你没有看错,整数的地板除//永远是整数,即使除不尽。要做精确的除法,使用/就可以。
因为//除法只取结果的整数部分,所以Python还提供一个余数运算,可以得到两个整数相除的余数:
>>> 10 % 3
1
无论整数做//除法还是取余数,结果永远是整数,所以,整数运算结果永远是精确的。
㈨ python中常量类型有哪些
常量定义:不可以被改变的量python中无固定语法,约定俗成的是将变量名全部大写。例如:
PI=3.141592653BIRTH_OF_SYLAR=1990
Python并未提供如C/C++/Java一样的const修饰符。
换言之,#python中没有常量。
python提供了新的方法实现常量:即通过自定义类实现常量。
需要满足两个条件:
命名全部为大写值,被赋值便不可再修改。
例如:
HOST=飗.0.0.1'