【Python】基础总结
输入
input("提示性信息")
如:
input("请输入数字")
评估函数
因为 Python 没有特别人为规定数据类型,数据类型是由计算机进行判定,所以我们 input()
输入的数据均默认作为字符串处理,而如果要输入一些数字,着需要 eval()
评估函数对字符串进行评估,化为语句(数字)。
评估函数:去掉参数最外侧引号并执行余下语句的函数,即 字符串 → 语句。
例如:
eval("1")
→ 1
eval("1+2")
→ 3
eval('"1+2"')
→ '1+2'
eval('print("hello")')
→ hello
输出
print(...)
默认空一行,如果想不空行,则
print(...., end = "")
数字类型
整数类型
与数学中整数的概念一致。
特性:
- 可正可负,没有取值范围限制
pow(x, y)
函数:计算\(x^y\),想算多大算多大
进制:
- 十进制:1010,99,-217
- 二进制:以 0b 或 0B 开头:0b010,-0B101
- 八进制:以 0o 或 0O 开头:0o123,-0O456
- 十六进制:以 0x 或 0X 开头:0x9a,-0X89
浮点数类型
与数学中实数的概念一致。
特性:
- 带有小数点及小数的数字
- 浮点数取值范围和小数精度都存在限制,但常规计算可忽略
- 取值范围数量级约为\(-10^{307}\)至\(10^{308}\),精度数量级\(10^{-16}\)
- 浮点数间运算存在不确定尾数,不是 bug
不确定尾数
浮点数间运算存在不确定尾数,不是 bug
如:0.1+0.3 → 0.4
0.1+0.2 → 0.30000000000000004
这是由于在计算机中一切数据都是化为二进制进行存储的,而有的浮点数并不能完全化为相等的二进制数,只能无限趋近于二进制数。
如:0.1 →
- 二进制表示:0.00011001100110011001100110011001100...等 53位二进制表示小数部分,约 \(10^{-16}\)
十进制表示:0.10000000000000000555111512312578270...
注意:二进制表示小数,可以无限接近,但不完全相同。
例如,0.1+0.2 结果无限趋近 0.3,但是可能存在尾数。
四舍五入
解决方法:
- 0.1+0.2 == 0.3 → False
- round(0.1+0.2, 1) == 0.3 → True
四舍五入:
round(x, d)
:对 x 四舍五入,d 是小数截取位数。- 浮点数间运算与比较用 round() 函数辅助
- 不确定尾数一般发生在 \(10^{-16}\) 左右,round() 十分有效
科学计数法
浮点数可以采用科学计数法表示
使用字母 e 或 E 作为幂的符号,以 10 为基数,格式如下:
<a>e<b>
表示 \(a*10^b\)例如:4.3e-3 值为 0.0043
9.6E5 值为 960000.0
复数类型
与数学中复数的概念一致,\(j^2\) = -1
例如:z = 1.23e-4 + 5.6e+89j
z.real 获得实部,z.imag 获得虚部
数值运算操作符
操作符及使用 | 描述 | 备注 |
---|---|---|
x // y | 整数除 | x 与 y之整数商 10//3 结果是 3 |
x % y | 余数,模运算 | 10%3 结果是 1 |
x ** y | 幂运算,x的y次幂,\(x^y\) | 也可以进行开方 |
+x | x 的本身 | |
-x | x 的负值 |
数字类型的关系
类型间课进行混合运算,生成结果为“最宽”类型
三种类型存在一种逐渐“扩展”或“变宽”的关系:
整数 → 浮点数 → 复数
例如:123+4.0 = 127.0(整数 + 浮点数 = 浮点数)
数值运算函数
函数及使用 | 描述 | 备注 |
---|---|---|
abs(x) | 绝对值,x 的绝对值 | abs(-10.01) 结果为 10.01 |
divmod(x, y) | 商余,(x//y, x%y),同时输出商和余数 | divmod(10, 3) 结果为 (3,1) |
pow(x, y[,z]) | 幂余,(x**y%z),[]表示参数z可省略 | pow(3, pow(3,99),10000) 结果为 4587 |
round(x[,d]) | 四舍五入,d 是保留小数位数,默认值为 0 | round(-10.123,2) 结果为 -10.12 |
max(x1,x2,...,xn) | 最大值,返回 x1,x2,...,xn 中的最大值,n 不限 | max(1,9,5,4,3) 结果为 9 |
min(x1,x2,...,xn) | 最小值,返回 x1,x2,...,xn 中的最小值,n 不限 | min(1,9,5,4,3) 结果为 1 |
int(x) | 将 x 变成整数,舍弃小数部分 | int(123.45)结果为123; int("123")结果为123 |
float(x) | 将 x 变成浮点数,增加小数部分 | float(12)结果为12.0; float("1.23")结果为1.23 |
complex(x) | 将 x 变成复数,增加虚数部分 | complex(4)结果为4+0j |
字符串类型
字符串类型的表示
字符串:由 0 个或多个字符组成的有序字符序列。
特点:
字符串由一对单引号或一对双引号表示
例如:"请输入带有符号的温度值:" 或者 'C'
字符串是字符的有序序列,可以对其中的字符进行索引
例如:"请"是"请输入带有符号的温度值:"的第 0 个字符
字符串有 2 类共 4 种表示方法:
由一对单引号或双引号表示,仅表示单行字符串
例如:"请输入带有符号的温度值:" 或者 'C'
由一对三单引号或三双引号表示,课表示多行字符串
例如:
'''
python
语言
'''
扩展:
- 如果希望在字符串中包含双引号或单引号呢?
'这里有个双引号(")' 或者 "这里有个单引号(')" - 如果希望在字符串中既包括单引号又包括双引号呢?
'''这里既有单引号(')又有双引号(")'''
字符串的序号
字符串的使用
使用[]获取字符串中一个或多个字符
索引:返回字符串中单个字符。[M]
例如:"请输入带有符号的温度值:"[0] 或者 TempStr[-1]
切片:返回字符串中一段字符子串。[M:N]
例如:"请输入带有符号的温度值:"[1:3] 或者 TempStr[0:-1]
字符串切片高级用法
使用[M:N:K]根据步长对字符串切片
[M:N],M 缺失表示至开头,N 缺失表示至结尾
例如:"零一二三四五六七八九十"[:3] 结果是 "零一二"
[M:N:K],根据步长 K 对字符串切片
例如:"零一二三四五六七八九十"[1:8:2] 结果是 "一三五七"
"零一二三四五六七八九十"[::-1] 结果是 "十九八七六五四三二一零"
字符串操作符
操作符及使用 | 描述 |
---|---|
x + y | 连接两个字符串 x 和 y |
x*n 或 n*x | 复制 n 次字符串 x |
x in s | 如果 x 是 s 的子串,返回 True,否则返回 False |
字符串处理函数
函数及使用 | 描述 | 备注 |
---|---|---|
len(x) | 长度,返回字符串 x 的长度 | len("一二三456")结果为6 |
str(x) | 任意类型 x 所对应的字符串形式 | str(1.23)结果为"1.23" str([1,2])结果为"[1,2]" |
oct(x) | 整数 x 的八进制小写形式字符串 | oct(425)结果为"0o651" |
hex(x) | 整数 x 的十六进制小写形式字符串 | hex(425)结果为"0x1a9" |
chr(u) | x 为 Unicode 编码,返回其对应的单字符 | |
ord(x) | x 为字符,返回其对应的 Unicode编码 |
字符串处理方法
方法及使用 | 描述 | 备注 |
---|---|---|
str.lower() | 返回字符串的副本,全部字符小写 | "AbCdEfGh".lower()结果为"abcdefgh" |
str.upper() | 返回字符串的副本,全部字符大写 | |
strsplit(sep=None) | 返回一个列表,由 str 根据 sep 被分隔的部分组成 | "A,B,C".split(",")结果为['A','B','C'] |
str.count(sub) | 返回子串 sub 在 str 中出现的次数 | "an apple a day".count("a")结果为4 |
str.replace(old, new) | 返回字符串 str 副本,所有 old 子串被替换为 new | "python".replace("n", "n123.io")结果为"python123.io" |
str.center(width[,fillchar]) | 字符串 str 根据宽度 width 居中,fillchar 可选 | "python".center(20,"=")结果为"=======python=======" |
str.strip(chars) | 从 str 中去掉在其左侧和右侧 chars中列出的字符 | "= python=".strip(" =np")结果为"ytho" |
str.join(iter) | 在 iter 变量除最后元素外每个元素后增加一个 str | ",".join("12345")结果为"1,2,3,4,5" |
字符串类型的格式化
格式化是对字符串进行格式表达的方式
- 字符串格式化使用.format()方法,用法如下:
.format()
槽内部对格式化的配置方式
{:}
: | <,> | <.精度> | ||||
---|---|---|---|---|---|---|
引号符号 | 用于填充的单个字符 | < 左对齐> 右对齐^ 居中对齐 |
槽设定的输出宽度 | 数字的千位分隔符 | 浮点数小数精度 或 字符串最大输出长度 | 整数类型b ,c ,d ,o ,x ,X 浮点数类型 e ,E ,f ,% |
填充、对齐、宽度这三个一组,例如:
"{0:=^20}".format("PYTHON")
→ '=======PYTHON======='
"{0:*>20}".format("BIT")
→ '*****************BIT'
"{:10}".format("BIT")
'BIT '
剩下的三个一组,例如:
"{0:,.2f}".format(12345.6789)
→ '12,345.68'
"{0:b},{0:c},{0:d},{0:o},{0:x},{0:X}x".format(425)
→ '110101001,Σ,425,651,1a9,1A9'
"{0:e},{0:E},{0:f},{0:%}".format(3.14)
'3.140000e+00,3.140000E+00,3.140000,314.000000%'
异常处理
try:
# 执行1
<语句块1>
except [<异常类型>]:
# 如果出现异常执行2
<语句块2>
[else:]
# 否则,不发生异常执行3
<语句块3>
[finally:]
# 最后执行4,一定执行
<语句块4>
使用 raise
语句抛出一个指定的异常。
raise [Exception [, args [, traceback]]]
分支结构
二分支结构
紧凑形式:适用于简单表达式的二分支结构
<表达式1> if <条件> else <表达式2>
例如:
guess = eval(input())
print("猜{}了".format("对" if guess==99 else "错"))
多分支结构
if
elif
else
循环结构
遍历循环
for <循环变量> in <遍历结构> :
<语句块>
- 从遍历结构中逐一提取元素,放在循环变量中
- 由保留字for和in组成,完整遍历所有元素后结束
- 每次循环,所获得元素放入循环变量,并执行一次语句块
计数循环(N次)
for i in range(N) :
<语句块>
- 遍历由
range()
函数产生的数字序列,产生循环
例如:
for i in range(5):
print("Hello:",i)
运行结果:
Hello: 0
Hello: 1
Hello: 2
Hello: 3
Hello: 4
计数循环(特定次)
for i in range(M,N,K) :
<语句块>
- 遍历由
range()
函数产生的数字序列,产生循环
例如:
for i in range(1,6,2):
print("Hello:",i)
运行结果:
Hello: 1
Hello: 3
Hello: 5
字符串遍历循环
for c in s :
<语句块>
- s是字符串,遍历字符串每个字符,产生循环
例如:
for c in "Python123":
print(c, end=",")
运行结果:
P,y,t,h,o,n,1,2,3,
列表遍历循环
for item in ls :
<语句块>
- ls是一个列表,遍历其每个元素,产生循环
例如:
for item in [123, "PY", 456] :
print(item, end=",")
运行结果:
123,PY,456,
文件遍历循环
for line in fi :
<语句块>
- fi是一个文件标识符,遍历其每行,产生循环
例如:
for line in fi :
print(line)
运行结果:
优美胜于丑陋
明了胜于隐晦
简洁胜于复杂
无限循环
由条件控制的循环运行方式
while <条件> :
<语句块>
- 反复执行语句块,直到条件不满足时结束
例如:
a = 3
while a > 0 :
a = a - 1
print(a)
运行结果:
2
1
0
扩展
for <变量> in <遍历结构> :
<语句块1>
else :
<语句块2>
while <条件> :
<语句块1>
else :
<语句块2>
- 当循环没有被break语句退出时,执行else语句块
- else语句块作为"正常"完成循环的奖励
- 这里else的用法与异常处理中else用法相似
例如:
for c in "PYTHON" :
if c == "T" :
continue
print(c, end="")
else:
print("正常退出")
运行结果:
PYHON正常退出
例如:
for c in "PYTHON" :
if c == "T" :
break
print(c, end="")
else:
print("正常退出")
运行结果:
PY
函数
- 函数定义时可以为某些参数指定默认值,构成可选参数
- 函数定义时可以设计可变数量参数,即 不确定参数总数量
- 函数调用时,参数可以按照位置或名称方式传递,如 f(1, 2) → f(m=1, n=2)
- 函数可以返回 0 个或多个结果(元组类型)
def <函数名>(<非可选参数> [,<可选参数>, <可变参数>]) :
<函数体>
return <返回值>
可选参数例如:
def f(m, n=1)
return m+n
print(f(1))
运行结果:
2
可变参数例如:
def f(*b):
sum = 0
for item in b:
sum += item
return sum
print(f(1,2,3,4,5))
运行结果:
15
在函数定义中,经常会碰到 *args(arguments) 和作为参数 **kwargs(keyword arguments)。
(事实上在函数中,和才是必要的,args 和 kwargs 可以用其他名称代替)
*args 是指不定数量的非键值对参数。
**kwargs 是指不定数量的键值对参数。
*args 作为作为元组匹配没有指定参数名的参数。而 **kwargs 作为字典,匹配指定了参数名的参数。
*args 必须位于 **kwargs 之前。
*args(*通常紧跟一个标识符,你会看到a或者args都是标识符)是python用于接收或者传递任意基于位置的参数的语法。当你接收到一个用这种语法描叙参数时(比如你在函数def语句中对函数签名使用了星号语法),python会将此标识符绑定到一个元祖,该元祖包含了所有基于位置的隐士的接收到的参数。当你用这种语法传递参数时,标识符可以被绑定到任何可迭代对象(事实上,它也可以是人和表达式,并不必须是一个标识符),只要这个表达式的结果是一个可迭代的对象就行。
**kwds(标识符可以是任意的,通常k或者kwds表示)是python用于接收或者传递任意基于位置的参数的语法。(python有时候会将命名参数称为关键字参数,他们其实并不是关键字--只是用他们来给关键字命名,比如pass,for或者yield,还有很多,不幸的是,这种让人疑惑的术语目前仍是这门语言极其文化根深蒂固的一个组成部分。)当你接收到用这种语法描叙的一个参数时(比如你在函数的def语句中对函数签名使用了双星号语法)python会将标识符绑定到一个字典,该字典包含了所有接收到的隐士的命名参数。当你用这种语法传递参数时,标识符只能被绑定到字典(我ID号I它也可以是表达式,不一定是一个标识符,只要这个表达式的结果是一个字典即可)。
当你在定义或调用一个函数的时候,必须确保a和k在其他所有参数之后。如果这两者同时出现,要将k放在a之后。
局部变量和全局变量
- 基本数据类型,无论是否重名,局部变量与全局变量不同
- 可以通过 global 保留字在函数内部声明全局变量
组合数据类型,如果局部变量未真实创建,则是全局变量
解释:组合数据类型是用指针来指明位置的,所以若局部变量未真实创建组合数据类型,它使用的变量是指针,而指针指的是外部的全局变量,所以你去修改指针对应的内容就修改了全局变量。
lambda 函数
lambda函数返回函数名作为结果
- lambda函数是一种匿名函数,即没有名字的函数
- 使用lambda保留字定义,函数名是返回结果
- lambda函数用于定义简单的、能够在一行内表示的函数
<函数名> = lambda <参数>: <表达式>
def <函数名>(<参数>) :
<函数体>
return <返回值>
例如:
f = lambda : "lambda函数"
print(f())
运行结果:
lambda函数
谨慎使用lambda函数
- lambda函数主要用作一些特定函数或方法的参数
- lambda函数有一些固定使用方式,建议逐步掌握
- 一般情况,建议使用def定义的普通函数
【Python】基础总结的更多相关文章
- python之最强王者(2)——python基础语法
背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- Python小白的发展之路之Python基础(一)
Python基础部分1: 1.Python简介 2.Python 2 or 3,两者的主要区别 3.Python解释器 4.安装Python 5.第一个Python程序 Hello World 6.P ...
- Python之路3【第一篇】Python基础
本节内容 Python简介 Python安装 第一个Python程序 编程语言的分类 Python简介 1.Python的由来 python的创始人为吉多·范罗苏姆(Guido van Rossum) ...
- 进击的Python【第三章】:Python基础(三)
Python基础(三) 本章内容 集合的概念与操作 文件的操作 函数的特点与用法 参数与局部变量 return返回值的概念 递归的基本含义 函数式编程介绍 高阶函数的概念 一.集合的概念与操作 集合( ...
- 进击的Python【第二章】:Python基础(二)
Python基础(二) 本章内容 数据类型 数据运算 列表与元组的基本操作 字典的基本操作 字符编码与转码 模块初探 练习:购物车程序 一.数据类型 Python有五个标准的数据类型: Numbers ...
- Python之路【第一篇】python基础
一.python开发 1.开发: 1)高级语言:python .Java .PHP. C# Go ruby c++ ===>字节码 2)低级语言:c .汇编 2.语言之间的对比: 1)py ...
- python基础之day1
Python 简介 Python是著名的“龟叔”Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言. Python为我们提供了非常完善的基础代码库,覆盖了 ...
- python基础之文件读写
python基础之文件读写 本节内容 os模块中文件以及目录的一些方法 文件的操作 目录的操作 1.os模块中文件以及目录的一些方法 python操作文件以及目录可以使用os模块的一些方法如下: 得到 ...
- python基础之编码问题
python基础之编码问题 本节内容 字符串编码问题由来 字符串编码解决方案 1.字符串编码问题由来 由于字符串编码是从ascii--->unicode--->utf-8(utf-16和u ...
随机推荐
- 《Docker从入门到跑路》之基本用法介绍
Docker是一种轻量级的虚拟化技术,它具备传统虚拟机无法比拟的优势,它更简易的安装和使用方式.更快的速度.服务集成和开源流程自动化. Docker的安装 安装Docker的基本要素:1.Docker ...
- Intersection of Two Linked Lists (求两个单链表的相交结点)
题目描述: Write a program to find the node at which the intersection of two singly linked lists begins. ...
- 自定义View实战
PS:上一篇从0开始学自定义View有博友给我留言说要看实战,今天我特意写了几个例子,供大家参考,所画的图案加上动画看着确实让人舒服,喜欢的博友可以直接拿到自己的项目中去使用,由于我这个写的是demo ...
- 【Hadoop离线基础总结】Hue与Mysql集成
Hue与Mysql集成 1.修改hue.ini配置文件 这里要去掉#,打开mysql注释,大概在1547行 [[[mysql]]] nice_name="My SQL DB" en ...
- pyltp安装教程及简单使用
1.pyltp简介 pyltp 是哈工大自然语言工作组推出的一款基于Python 封装的自然语言处理工具(轮子),提供了分词,词性标注,命名实体识别,依存句法分析,语义角色标注的功能. 2.pyltp ...
- JDBC07 事务
事务 事务基本概念 一组要么同时执行成功,要么同时执行失败的SQL语句,是数据库操作的一个执行单元(比如:银行中,对账户的操作和日志的记录是一组事务) 事务开始于: -连接到数据库上,并执行一条DML ...
- FZU2105 线段树 (按位操作)
题目: Given N integers A={A[0],A[1],...,A[N-1]}. Here we have some operations: (元素和操作元素 < 16) Opera ...
- [hdu4599]期望DP
思路:容易知道G(x)=6x,H(x)=6F(x).此题的关键是求出F(x)的通项,要求F(x)的通项,先建立递推式:F(x)=1/6 * (F(x-1)+1) + 5/6 * (F(x-1)+1+F ...
- org.springframework.web.bind.annotation不存在 site:blog.csdn.net(IDEA中运行springboot时报错)
原因:MAVEN版本与IDEA版本不兼容问题, maven虽然更新比较慢,但是最新的3.6.6在与IDEA2019版本及以下版本兼容时会出现以上问题 解决办法:重新配置一个3.6低级别版本的maven ...
- 垃圾收集器与内存分配策略——深入理解Java虚拟机 笔记二
在本篇中,作者大量篇幅介绍了当时较为流行的垃圾回收器,但现在Java 14都发布了,垃圾收集器也是有了很大的进步和发展,因此在此就不再对垃圾收集器进行详细的研究.但其基本的算法思想还是值得我们参考学习 ...