Python-Core-50-Courses/第003课:Python语言元素之变量.md

112 lines
8.5 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

## 第003课Python语言元素之变量
作为一个程序员,可能经常会被外行人问到两个问题,其一是“什么是(计算机)程序”,其二是“写(计算机)程序能做什么”,这里我们先对两个问题做一个回答。**程序是指令的集合****写程序就是用指令控制计算机做我们想让它做的事情**。那么为什么要用Python语言来写程序呢因为**Python语言简单优雅**相比C、C++、Java这样的编程语言**Python对初学者更加友好**当然这并不是说Python不像其他语言那样强大**Python几乎是无所不能的**在第一节课的时候我们就说到了Python可以用于服务器程序开发、云平台开发、数据分析、机器学习等各个领域。当然Python语言还可以用来粘合其他语言开发的系统所以也经常被戏称为“**胶水语言**”。
### 一些计算机常识
在开始系统的学习编程之前,我们先来科普一些计算机的基础知识。计算机的硬件系统通常由五大部件构成,包括:**运算器**、**控制器**、**存储器**、**输入设备**和**输出设备**。其中,运算器和控制器放在一起就是我们常说的**中央处理器**,它的功能是执行各种运算和控制指令。刚才我们提到过程序是指令的集合,写程序就是将一系列的指令按照某种方式组织到一起,然后通过这些指令去控制计算机做我们想让它做的事情。目前,我们使用的计算机基本都是“冯·诺依曼体系结构”的计算机,这种计算机有两个关键点:一是要将**存储设备与中央处理器分开**;二是将**数据以二进制方式编码**。
二进制是一种“逢二进一”的计数法跟我们人类使用的“逢十进一”的计数法本质是一样的。人类因为有十根手指所以使用了十进制因为在计数时十根手指用完之后就只能用进位的方式来表示更大的数值。当然凡事都有例外玛雅人可能是因为长年光着脚的原因把脚趾头也都用上了于是他们使用了二十进制的计数法。在这种计数法的指导下玛雅人的历法就与我们平常使用的历法并不相同。按照玛雅人的历法2012年是上一个所谓的“太阳纪”的最后一年而2013年则是新的“太阳纪”的开始后来这件事情被以讹传讹的方式误传为”2012年是玛雅人预言的世界末日“的荒诞说法。今天很多人都在猜测玛雅文明之所以发展缓慢跟使用了二十进制是有关系的。对于计算机来说二进制在物理器件上最容易实现的因为可以用高电压表示1用低电压表示0。不是所有写程序的人都需要知道十进制与二进制如何转换大多数时候我们即便不了解这些知识也能写出程序但是我们必须要知道**计算机是使用二进制计数的**,不管什么**数据到了计算机内存中都是以二进制形式存在的**。
### 变量和类型
要想在计算机内存中保存数据,首先就得说一说变量这个概念。在编程语言中,**变量是数据的载体**,简单的说就是一块用来保存数据的内存空间,**变量的值可以被读取和修改**,这是所有计算和控制的基础。计算机能处理的数据有很多种类型,最常见的就是数值,除了数值之外还有文本、图形、音频、视频等各种各样的数据。虽然数据在计算机中都是以二进制形态存在的,但是我们可以用不同类型的变量来表示数据类型的差异。**Python中的数据类型很多**,而且也**允许我们自定义新的数据类型**(这一点在后面会讲到),这里我们需要先了解几种常用的数据类型。
- 整型intPython中可以处理任意大小的整数而且支持二进制如`0b100`换算成十进制是4、八进制如`0o100`换算成十进制是64、十进制`100`)和十六进制(`0x100`换算成十进制是256的表示法。
- 浮点型float浮点数也就是小数之所以称为浮点数是因为按照科学记数法表示时一个浮点数的小数点位置是可变的浮点数除了数学写法如`123.456`)之外还支持科学计数法(如`1.23456e2`)。
- 字符串型str字符串是以单引号或双引号括起来的任意文本比如`'hello'`和`"hello"`。
- 布尔型bool布尔值只有`True`、`False`两种值,要么是`True`,要么是`False`。
### 变量命名
对于每个变量我们需要给它取一个名字就如同我们每个人都有自己的名字一样。在Python中变量命名需要遵循以下这些规则这些规则又分为必须遵守的硬性规则和建议遵守的非硬性规则。
- 硬性规则:
- 规则1变量名由**字母**、数字和**下划线**构成数字不能开头。需要说明的是这里说的字母指的是Unicode字符Unicode称为万国码囊括了世界上大部分的文字系统这也就意味着中文、日文、希腊字母等都可以作为变量名中的字符但是像`!`、`@`、`#`这些特殊字符是不能出现在变量名中的,而且我们强烈建议大家**尽可能使用英文字母**。
- 规则2**大小写敏感**,简单的说就是大写的`A`和小写的`a`是两个不同的变量。
- 规则3变量名**不要跟Python语言的关键字**(有特殊含义的单词,后面会讲到)和**保留字**(如函数、模块等的名字)**发生重名的冲突**。
- 非硬性规则:
- 规则1变量名通常使用小写英文字母多个单词用下划线进行连接。
- 规则2受保护的变量用单个下划线开头后面会讲到
- 规则3私有的变量用两个下划线开头后面会讲到
当然,作为一个专业的程序员,给变量(事实上应该是所有的标识符)命名时做到**见名知意**也非常重要。
### 变量的使用
下面通过例子来说明变量的类型和变量的使用。
```Python
"""
使用变量保存数据并进行加减乘除运算
Version: 0.1
Author: 骆昊
"""
a = 45 # 变量a保存了45
b = 12 # 变量b保存了12
print(a + b) # 57
print(a - b) # 33
print(a * b) # 540
print(a / b) # 3.75
```
在Python中可以使用`type`函数对变量的类型进行检查。程序设计中函数的概念跟数学上函数的概念基本一致,数学上的函数相信大家并不陌生,它包括了函数名、自变量和因变量。如果暂时不理解函数这个概念也不要紧,我们会在后续的内容中专门讲解函数的定义和使用。
```Python
"""
使用type()检查变量的类型
Version: 0.1
Author: 骆昊
"""
a = 100
b = 12.345
c = 'hello, world'
d = True
print(type(a)) # <class 'int'>
print(type(b)) # <class 'float'>
print(type(c)) # <class 'str'>
print(type(d)) # <class 'bool'>
```
不同类型的变量可以相互转换这一点可以通过Python的内置函数来实现。
- `int()`:将一个数值或字符串转换成整数,可以指定进制。
- `float()`:将一个字符串转换成浮点数。
- `str()`:将指定的对象转换成字符串形式,可以指定编码。
- `chr()`:将整数转换成该编码对应的字符串(一个字符)。
- `ord()`:将字符串(一个字符)转换成对应的编码(整数)。
下面的例子为大家演示了Python中类型转换的操作。
```Python
"""
Python中的类型转换操作
Version: 0.1
Author: 骆昊
"""
a = 100
b = 12.345
c = 'hello, world'
d = True
# 整数转成浮点数
print(float(a)) # 100.0
# 浮点型转成字符串 (输出字符串时不会看到引号哟)
print(str(b)) # 12.345
# 字符串转成布尔型 (有内容的字符串都会变成True)
print(bool(c)) # True
# 布尔型转成整数 (True会转成1False会转成0)
print(int(d)) # 1
# 将整数变成对应的字符 (97刚好对应字符表中的字母a)
print(chr(97)) # a
# 将字符转成整数 (Python中字符和字符串表示法相同)
print(ord('a')) # 97
```
### 总结
在Python程序中我们可以**使用变量来保存数据****变量有不同的类型****变量可以做运算**(下一课会有详细的讲解),**也可以通过内置函数来转换变量类型**。
>**温馨提示**:学习中如果遇到困难,可以加**QQ交流群**询问,群号:**789050736**,当然也可以看看我们为大家录制的入门视频,视频的链接地址:<https://pan.baidu.com/s/10y7sGM016YBM7gDdauGqLw>密码4s6r。