Python 语言入门

栏目: Python · 发布时间: 4年前

内容简介:Python 在各领域的应用已经非常广泛了,尤其是最近热门的人工智能等领域。现在开始学习 Python 语言基础,后面利用强大的工具库,想必事半功倍。1、Python 的注释:

Python 在各领域的应用已经非常广泛了,尤其是最近热门的人工智能等领域。

现在开始学习 Python 语言基础,后面利用强大的 工具 库,想必事半功倍。

Python 基础语法

1、Python 的注释:

# 单行注释
print ("Hello, Python!") # 单行注释

'''
多行注释
多行注释
'''

"""
多行注释
多行注释
"""

单行注释使用 # 号,多行注释使用 '''"""

2、Python 的行与缩进

Python 中使用缩进表示代码块,不使用 {}

if True:
    print ("True")
else:
    print ("False")

如果缩进不一致,会导致错误。

Python 中一条语句换行需要使用反斜杠( \ )表示:

total = item_one + \
        item_two + \
        item_three

3、end 关键字

# Fibonacci series: 斐波纳契数列
a, b = 0, 1
while b < 1000:
    print(b, end=',')
    a, b = b, a+b

# 1,1,2,3,5,8,13,21,34,55,89,144,233,377,610,987,

关键字 end 可以用于将结果输出到同一行,或者在末尾添加不同的字符。

Python 基本数据类型

Python 中的变量不需要声明。

Python3 中有六个标准的数据类型:

Number(数字)、String(字符串)、Tuple(元组)、List(列表)、Set(集合)、Dictionary(字典)。

其中前三个为不可变数据类型,后三个为可变数据类型。

1、Number(数字):Python3 支持 int、float、bool、complex(复数)。

其中 在 Python3 中 True 和 False 为关键字,值分别为 1 和 0,可以和数字相加。

2、String(字符串):使用单引号 ' 或双引号 " 括起来,使用反斜杠 \ 转义特殊字符。

str = 'wshunli'

print(str)           # 输出字符串
print(str[0])        # 输出字符串第一个字符
print(str[2:4])      # 输出第三个开始到第四个的字符
print(str[0:-1])     # 输出第一个到倒数第二个的所有字符
print(str[2:])       # 输出从第三个开始的后的所有字符
print(str * 2)       # 输出字符串两次
print(str + ".com")  # 连接字符串

# wshunli
# w
# hu
# wshunl
# hunli
# wshunliwshunli
# wshunli.com

Python 三引号:一个字符串跨多行。

para_str = """这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( \t )。
也可以使用换行符 [ \n ]。
"""
print(para_str)

# 这是一个多行字符串的实例
# 多行字符串可以使用制表符
# TAB (      )。
# 也可以使用换行符 [ 
#  ]。

3、List(列表):列表可以完成大多数集合类的数据结构实现。方括号 [] 表示。

列表中元素的类型可以不同,支持数字,字符串以及列表(嵌套)。

列表的索引和截取和字符串类似;但是支持第3个参数表示截取步长。

letters = ['w','s','h','u','n','l','i']
letters[1:4:2]

# ['s','u']

4、Tuple(元组):元素不能修改的列表。小括号 () 表示。

虽然 Tuple 的元素不可改变,但可以包含可变的对象,比如 List 列表。

String、List 和 Tuple 都属于 Sequence(序列)。

5、Set(集合):集合元素之间不相同、不可变、无序。大括号 {} 表示。

集合运算:

a = set('abracadabra')
b = set('alacazam')

print(a)
print(a - b)     # a 和 b 的差集
print(a | b)     # a 和 b 的并集
print(a & b)     # a 和 b 的交集
print(a ^ b)     # a 和 b 中不同时存在的元素

# {'b', 'a', 'c', 'r', 'd'}
# {'b', 'd', 'r'}
# {'l', 'r', 'a', 'c', 'z', 'm', 'b', 'd'}
# {'a', 'c'}
# {'l', 'r', 'z', 'm', 'b', 'd'}

6、Dictionary(字典):无序的 键(key) : 值(value) 的集合。大括号 {} 表示。

其中 键(key) 为不可变类型。在同一个字典中,键(key) 必须是唯一的。

tinydict = {'name': 'wshunli', 2: 1, 'site': 'wshunli.com'}

print (tinydict)          # 输出完整的字典
print (tinydict['name'])  # 输出键为 'one' 的值
print (tinydict[2])       # 输出键为 2 的值
print (tinydict.keys())   # 输出所有键
print (tinydict.values()) # 输出所有值

# {'name': 'wshunli', 2: 1, 'site': 'wshunli.com'}
# wshunli
# 1
# dict_keys(['name', 2, 'site'])
# dict_values(['wshunli', 1, 'wshunli.com'])

基本数据类型的创建:

list = []    # 构造 0 个的列表
tup1 = ()    # 构造 0 个的元组
tup2 = (20,) # 构造 1 个的元组
set = set()  # 构造 0 个的集合
dirt = []    # 构造 0 个的字典

Python 运算符

(1)Python 算术运算符:+、-、 、/、%、* 、//

** 幂 - 返回 x 的 y 次幂

a**b       # a 的 b 次方

// 取整除 - 向下取接近除数的整数

>>> 9//2   # 4
>>> -9//2  # -5

(2)Python 比较运算符:==、!=、>、>=、<、<=

(3)Python 赋值运算符:=、+=、-=、 =、/=、%=、* 、//=

(4)Python 位运算符:&、|、^ 、~ 、<<、>>

(5)Python 逻辑运算符:and、or、not

(6)Python 成员运算符:in、not in

(7)Python 身份运算符:is、is not

is 是判断两个标识符是不是引用自一个对象;

is not 是判断两个标识符是不是引用自不同对象

Python 条件控制

if condition_1:
    statement_block_1
elif condition_2:
    statement_block_2
else:
    statement_block_3

在 Python 中没有 switch – case 语句。

Python 循环语句

1、While 循环

while … else 在条件语句为 false 时执行 else 的语句块:

count = 0
while count < 3:
   print (count, " 小于 3")
   count = count + 1
else:
   print (count, " 大于或等于 3")

# 0  小于 3
# 1  小于 3
# 2  小于 3
# 3  大于或等于 3

2、For 循环:遍历任何序列的项目,如列表、字符串。

for <variable> in <sequence>:
    <statements>
else:
    <statements>

3、range() 函数

range() 函数用于生成数列:

for i in range(5):
    print(i, end=',')

for i in range(5, 9):
    print(i, end=',')

for i in range(0, 10, 3):
    print(i, end=',')

for i in range(-1, -10, -3):
    print(i, end=',')

list(range(5))

# 0,1,2,3,4,
# 5,6,7,8,
# 0,3,6,9,
# -1,-4,-7,
# [0, 1, 2, 3, 4]

结合 range() 和 len() 函数遍历一个序列的索引:

a = ['Google', 'Baidu', 'Runoob', 'Taobao', 'QQ']
for i in range(len(a)):
     print(i, a[i])

# 0 Google
# 1 Baidu
# 2 Runoob
# 3 Taobao
# 4 QQ

4、pass 语句

Python pass是空语句,是为了保持程序结构的完整性。

while True:
    pass  # 等待键盘中断 (Ctrl+C)

for letter in 'wshunli':
    if letter == 'n':
        pass
        print('执行 pass 块')
    print('当前字母 :', letter)

print("Good bye!")

# 当前字母 : w
# 当前字母 : s
# 当前字母 : h
# 当前字母 : u
# 执行 pass 块
# 当前字母 : n
# 当前字母 : l
# 当前字母 : i
# Good bye!

Python 迭代器与生成器

1、迭代器:用于遍历集合元素。

(1)迭代器的使用

迭代器有两个基本的方法: iter()next()

list = [1, 2, 3, 4]
it = iter(list)             # 创建迭代器对象
print(next(it), end=',')    # 输出迭代器的下一个元素
print(next(it), end=',')    # 输出迭代器的下一个元素

# 1,2,

迭代器可以使用 for 语句进行遍历:

list=[1, 2, 3, 4]
it = iter(list)    # 创建迭代器对象
for x in it:
    print(x, end=",")

# 1,2,3,4,

(2)迭代器的创建

在类中实现 __iter__()__next__() 两个方法。

class MyIter:
    def __iter__(self):
        self.a = 1
        return self

    def __next__(self):
        x = self.a
        self.a += 1
        return x

myIter = MyIter()
iter = iter(myIter)

print(next(iter), end=",")
print(next(iter), end=",")
print(next(iter), end=",")
print(next(iter), end=",")
print(next(iter), end=",")

# 1,2,3,4,5,

(3)StopIteration 异常

StopIteration 异常用于标识迭代的完成,防止出现无限循环的情况。

class MyIter:
    def __iter__(self):
        self.a = 1
        return self

    def __next__(self):
        if self.a <= 10:
            x = self.a
            self.a += 1
            return x
        else:
            raise StopIteration

myIter = MyIter()
iter = iter(myIter)

for x in iter:
    print(x, end=",")

# 1,2,3,4,5,6,7,8,9,10,

2、生成器

在 Python 中,使用了 yield 的函数被称为生成器(generator)。

调用一个生成器函数,返回的是一个迭代器对象。

import sys

def fibonacci(n):  # 生成器函数 - 斐波那契
    a, b, counter = 0, 1, 0
    while True:
        if (counter > n):
            return
        yield a
        a, b = b, a + b
        counter += 1


f = fibonacci(10)  # f 是一个迭代器,由生成器返回生成

while True:
    try:
        print(next(f), end=" ")
    except StopIteration:
        sys.exit()

# 0 1 1 2 3 5 8 13 21 34 55

每次调用生成器函数都会在 yield 处暂停并保存运行状态,返回 yield 结果;在下次执行 next() 函数时从暂停位置继续运行。

Python 函数

1、函数的定义

def hello() :
   print("Hello World!")

hello()

# Hello World!

2、函数的参数及其传递

Python 参数类型:必需参数、关键字参数、默认参数、不定长参数

def printinfo(arg1, arg2, arg3="默认值", *arg4, **arg5):
    print(arg1, end=";")
    print(arg2, end=";")
    print(arg3, end=";")
    print(arg4, end=";")
    print(arg5)

# printinfo();
printinfo("欢迎", "wshunli")
printinfo(arg2="欢迎", arg1="wshunli")
printinfo("欢迎", "wshunli", "访问")
printinfo("欢迎", "wshunli", "访问", "wshunli", ".com")
printinfo("欢迎", "wshunli", "访问", "wshunli", ".com", domain="wshunli", suffix=".com")

# 欢迎;wshunli;默认值;();{}
# wshunli;欢迎;默认值;();{}
# 欢迎;wshunli;访问;();{}
# 欢迎;wshunli;访问;('wshunli', '.com');{}
# 欢迎;wshunli;访问;('wshunli', '.com');{'domain': 'wshunli', 'suffix': '.com'}

其中 arg1 , arg2 属于必需参数,通过关键字传递时可以交换顺序;

arg3 属于默认参数,在没有传值时使用默认值;

arg4 , arg5 属于可变参数, * 元祖形式, ** 字典形式

声明函数时,参数中星号 * 可以单独出现,例如:

def f(a, b, *, c):
    return a + b + c

f(1, 2, 3)    # 报错
f(1, 2, c=3)  # 正常

星号 * 后的参数必须用关键字传入。

不可变类型类似于 传值 传递;可变类型类似于 传址 传递。

3、匿名函数

Python 使用 lambda 来创建匿名函数。

sum = lambda arg1, arg2: arg1 + arg2
# 调用 sum 函数
print("相加后的值为 : ", sum(10, 20))
print("相加后的值为 : ", sum(20, 20))

4、变量作用域

Python 的作用域一共有 4 种:局部作用域、闭包函数外的函数中、全局作用域、内置作用域(内置函数所在模块的范围)

g_count = 0  # 全局作用域
def outer():
    o_count = 1  # 闭包函数外的函数中
    def inner():
        i_count = 2  # 局部作用域

内置作用域是通过一个名为 builtin 的标准模块来实现的:

import builtins
dir(builtins)

改变变量的作用域:使用 globalnonlocal 关键字。

num1 = 1
num2 = 2

def outer():
    global num1        # global 关键字
    print("outer>>num1=", num1)
    num1 = 123
    print("outer>>num1=", num1)

    num2 = 20
    def inner():
        nonlocal num2  # nonlocal 关键字
        print("inner>>num2=", num2)
        num2 = 456
        print("inner>>num2=", num2)

    inner()
    print("outer>>num2=", num2)

outer()
print("num1=", num1)
print("num2=", num2)

# outer>>num1= 1
# outer>>num1= 123
# inner>>num2= 20
# inner>>num2= 456
# outer>>num2= 456
# num1= 123
# num2= 2

其中 global : 局部作用域 -> 全局作用域; nonlocal : 局部作用域 -> 闭包函数外的函数中

Python 模块

在 Python 中将一些方法和变量保存在文件中以供其他程序使用。

1、import 语句

import module1[, module2[,... moduleN]

2、from … import 语句:仅导入指定的部分(函数、变量)到当前命名空间中。

from modelname import name1[, name2[, ... nameN]]

__name__ 属性:值为 '__main__' 代表模块自身在运行,否则是被引入的。

dir() 函数:列出模块内定义的所有名称。

Python 异常处理

Python 中使用 tryexcept 处理异常:

while True:
    try:
        x = int(input("Please enter a number: "))
        break
    except ValueError:
        print("Oops!  That was no valid number.  Try again   ")

# Please enter a number: w
# Oops!  That was no valid number.  Try again   
# Please enter a number: 1

同时处理多个异常,可使用元组元组表示:

except (RuntimeError, TypeError, NameError):
        pass

Python 使用 raise 语句抛出一个指定的异常。

如果本文对您有所帮助,且您手头还很宽裕,欢迎打赏赞助我,以支付网站服务器和域名费用。 Python 语言入门 您的鼓励与支持是我更新的最大动力,我会铭记于心,倾于博客。

本文链接: https://www.wshunli.com/posts/fa771b3.html


以上所述就是小编给大家介绍的《Python 语言入门》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

利用Python进行数据分析

利用Python进行数据分析

Wes McKinney / 唐学韬 / 机械工业出版社 / 2013-11-18 / 89.00

【名人推荐】 “科学计算和数据分析社区已经等待这本书很多年了:大量具体的实践建议,以及大量综合应用方法。本书在未来几年里肯定会成为Python领域中技术计算的权威指南。” ——Fernando Pérez 加州大学伯克利分校 研究科学家, IPython的创始人之一 【内容简介】 还在苦苦寻觅用Python控制、处理、整理、分析结构化数据的完整课程?本书含有大量的实践案例,......一起来看看 《利用Python进行数据分析》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

SHA 加密
SHA 加密

SHA 加密工具