标签:商业 十六进制 负数 字符串表 包括 text none 专业 自定义
本文收录在Python从入门到精通系列文章系列
计算机的硬件系统通常由五大部件构成,包括:运算器、控制器、存储器、输入设备和输出设备。
其中,运算器和控制器放在一起就是我们通常所说的中央处理器,它的功能是执行各种运算和控制指令以及处理计算机软件中的数据。我们通常所说的程序实际上就是指令的集合,我们程序就是将一系列的指令按照某种方式组织到一起,然后通过这些指令去控制计算机做我们想让它做的事情。
今天我们大多数时候使用的计算机,虽然它们的元器件做工越来越精密,处理能力越来越强大,但究其本质来说仍然属于“冯·诺依曼结构”的计算机。“冯·诺依曼结构”有两个关键点,一是指出要将存储设备与中央处理器分开,二是提出了将数据以二进制方式编码。
二进制是一种“逢二进一”的计数法,跟我们人类使用的“逢十进一”的计数法没有实质性的区别,人类因为有十根手指所以使用了十进制(因为在数数时十根手指用完之后就只能进位了,当然凡事都有例外,玛雅人可能是因为长年光着脚的原因把脚趾头也算上了,于是他们使用了二十进制的计数法,在这种计数法的指导下玛雅人的历法就与我们平常使用的历法不一样,而按照玛雅人的历法,2012年是上一个所谓的“太阳纪”的最后一年,而2013年则是新的“太阳纪”的开始,后来这件事情被以讹传讹的方式误传为”2012年是玛雅人预言的世界末日“这种荒诞的说法,今天我们可以大胆的猜测,玛雅文明之所以发展缓慢估计也与使用了二十进制有关)。
对于计算机来说,二进制在物理器件上来说是最容易实现的(高电压表示1,低电压表示0),于是在“冯·诺依曼结构”的计算机都使用了二进制。虽然我们并不需要每个程序员都能够使用二进制的思维方式来工作,但是了解二进制以及它与我们生活中的十进制之间的转换关系,以及二进制与八进制和十六进制的转换关系还是有必要的。如果你对这一点不熟悉,可以自行使用维基百科或者百度百科科普一下。
提示:近期关于量子计算机的研究已经被推倒了风口浪尖,量子计算机基于量子力学进行运算,使用量子瞬移的方式来传递信息。2018年6月,Intel宣布开发出新款量子芯片并通过了在接近绝对零度环境下的测试;2019年1月,IBM向全世界发布了首款商业化量子计算机。
在程序设计中,变量是一种存储数据的载体。计算机中的变量是实际存在的数据或者说是存储器中存储数据的一块内存空间,变量的值可以被读取和修改,这是所有计算和控制的基础。
计算机能处理的数据有很多种类型,除了数值之外还可以处理文本、图形、音频、视频等各种各样的数据,那么不同的数据就需要定义不同的存储类型。Python中的数据类型很多,而且也允许我们自定义新的数据类型(这一点在后面会讲到),我们先介绍几种常用的数据类型。
对于每个变量我们需要给它取一个名字,就如同我们每个人都有属于自己的响亮的名字一样。在Python中,变量命名需要遵循以下这些必须遵守硬性规则和强烈建议遵守的非硬性规则。
n 变量名由字母(广义的Unicode字符,不包括特殊字符)、数字和下划线构成,数字不能开头。
n 不要跟关键字(有特殊含义的单词,后面会讲到)和系统保留字(如函数、模块等的名字)冲突。
当然,作为一个专业的程序员,给变量(事实上应该是所有的标识符)命名时做到见名知意也是非常重要的。
""" 使用变量保存数据并进行算术运算 Version: 0.1 Author: along """ a = 21 b = 12 print(a + b) print(a - b) print(a * b) print(a / b) print(a // b) print(a % b) print(a ** b)
注:Python算术运算符
运算符 |
描述 |
实例 |
+ |
加 - 两个对象相加 |
a + b 输出结果 33 |
- |
减 - 得到负数或是一个数减去另一个数 |
a - b 输出结果 9 |
* |
乘 - 两个数相乘或是返回一个被重复若干次的字符串 |
a * b 输出结果 252 |
/ |
除 - x除以y |
a / b 输出结果 1.75 |
% |
取模 - 返回除法的余数 |
a % b 输出结果 9 |
** |
幂 - 返回x的y次幂 |
a**b 为21的12次方结果为 7355827511386641 |
// |
取整除 - 返回商的整数部分(向下取整) |
a // b 输出结果 1 |
在Python中可以使用type函数对变量的类型进行检查。程序设计中函数的概念跟数学上函数的概念是一致的,数学上的函数相信大家并不陌生,它包括了函数名、自变量和因变量。如果暂时不理解这个概念也不要紧,我们会在后续的章节中专门讲解函数的定义和使用。
""" 使用type()检查变量的类型 Version: 0.1 Author: along """ a = 100 b = 12.345 c = 1 + 5j d = ‘hello, world‘ e = True print(type(a)) # <class ‘int‘> print(type(b)) # <class ‘float‘> print(type(c)) # <class ‘complex‘> print(type(d)) # <class ‘str‘> print(type(e)) # <class ‘bool‘>
可以使用Python中内置的函数对变量类型进行转换。
l int():将一个数值或字符串转换成整数,可以指定进制。
l str():将指定的对象转换成字符串形式,可以指定编码。
l chr():将整数转换成该编码对应的字符串(一个字符)。
l ord():将字符串(一个字符)转换成对应的编码(整数)。
""" 使用input()函数获取键盘输入(字符串) 使用int()函数将输入的字符串转换成整数 使用print()函数输出带占位符的字符串 Version: 0.1 Author: along """ a = int(input(‘a = ‘)) b = int(input(‘b = ‘)) c = float(input(‘c = ‘)) print(‘%d + %d = %d‘ % (a, b, a + b)) print(‘%d - %f = %f‘ % (a, c, a - c)) print(‘%d * %f = %f‘ % (a, c, a * c)) print(‘%d / %d = %f‘ % (a, b, a / b)) print(‘%d // %d = %d‘ % (a, b, a // b)) print(‘%d %% %d = %d‘ % (a, b, a % b)) print(‘%d ** %d = %d‘ % (a, b, a ** b))
说明:上面的print函数中输出的字符串使用了占位符语法,其中%d是整数的占位符,%f是小数的占位符,%%表示百分号(因为百分号代表了占位符,所以带占位符的字符串中要表示百分号必须写成%%),字符串之后的%后面跟的变量值会替换掉占位符然后输出到终端中,运行上面的程序,看看程序执行结果就明白啦。
Python支持多种运算符,下表大致按照优先级从高到低的顺序列出了所有的运算符,运算符的优先级指的是多个运算符同时出现时,先做什么运算然后再做什么运算。除了我们之前已经用过的赋值运算符和算术运算符,我们稍后会陆续讲到其他运算符的使用。
运算符 |
描述 |
[] [:] |
下标,切片 |
** |
指数 |
~ + - |
按位取反, 正负号 |
* / % // |
乘,除,模,整除 |
+ - |
加,减 |
>> << |
右移,左移 |
& |
按位与 |
^ | |
按位异或,按位或 |
<= < > >= |
小于等于,小于,大于,大于等于 |
== != |
等于,不等于 |
is is not |
身份运算符 |
in not in |
成员运算符 |
not or and |
逻辑运算符 |
= += -= *= /= %= //= **= &= ` |
= ^= >>= <<=` |
说明: 在实际开发中,如果搞不清楚运算符的优先级,可以使用括号来确保运算的执行顺序。
""" 赋值运算符和复合赋值运算符 Version: 0.1 Author: along """ a = 10 b = 5 a += b # 相当于:a = a + b a *= a + 2 # 相当于:a = a * (a + 2) print(a) # 想想这里会输出什么
下面的例子演示了比较运算符(关系运算符)、逻辑运算符和身份运算符的使用。
""" 比较、逻辑和算身份运算符的使用 Version: 0.1 Author: along """ flag0 = 1 == 1 flag1 = 3 > 2 flag2 = 2 < 1 flag3 = flag1 and flag2 flag4 = flag1 or flag2 flag5 = not (1 != 2) print(‘flag0 =‘, flag0) # flag0 = True print(‘flag1 =‘, flag1) # flag1 = True print(‘flag2 =‘, flag2) # flag2 = False print(‘flag3 =‘, flag3) # flag3 = False print(‘flag4 =‘, flag4) # flag4 = True print(‘flag5 =‘, flag5) # flag5 = False print(flag1 is True) # True print(flag2 is not False) # False
注释:一真或为真,一假且为假(背起上学的口令)
提示:华氏温度到摄氏温度的转换公式为:$C=(F - 32) \div 1.8$。
""" 将华氏温度转换为摄氏温度 Version: 0.1 Author: along """ f = float(input(‘请输入华氏温度: ‘)) c = (f - 32) / 1.8 print(‘%.1f华氏度 = %.1f摄氏度‘ % (f, c))
注:%.1f 指取1个余数的小数。
""" 输入半径计算圆的周长和面积 Version: 0.1 Author: along """ import math r=float(input(‘请输入圆的半径: ‘)) C=2 * math.pi * r S=math.pi * r * r print(‘周长为: %.2f‘ % C ) print(‘面积为: %.2f‘ % S )
""" 输入年份 如果是闰年输出True 否则输出False Version: 0.1 Author: along """ year = int(input(‘请输入年份: ‘)) # 如果代码太长写成一行不便于阅读 可以使用\对代码进行折行 is_leap = (year % 4 == 0 and year % 100 != 0) or year % 400 == 0 print(is_leap)
标签:商业 十六进制 负数 字符串表 包括 text none 专业 自定义
原文地址:https://www.cnblogs.com/along21/p/11830055.html