继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Python编程基础

扬帆大鱼
关注TA
已关注
手记 263
粉丝 13
获赞 50
概述

本文详细介绍了Python编程的基础内容,涵盖从安装到环境设置,再到编程入门、面向对象编程、数据结构、文件操作、网络编程、数据库操作、Python脚本编写等各个方面。通过丰富的示例代码和项目实例,读者可以全面掌握Python的核心技能,提升编程效率。

1. Python简介

Python是一种高级编程语言,由Guido van Rossum于1989年底开始设计,首版发布于1991年。它以简洁、易读的语法而闻名,广泛应用于网站开发、数据分析、人工智能、机器学习、自动化脚本等领域。Python的设计哲学强调代码的可读性,使用简单的语法和结构化的方式来减少程序的复杂性。

Python拥有一个庞大的标准库以及外部库,这些库提供了广泛的工具,可以处理从网络到文件系统的几乎所有内容。Python支持多种编程范式,包括面向对象、命令式、函数式和过程式编程。

2. 安装Python

Python可以从官方网站下载:https://www.python.org/。根据操作系统选择合适的版本进行安装。安装过程中,确保勾选“Add Python to PATH”选项,这将使Python安装在系统的环境变量中,以便在命令行中直接调用。

安装完成后,可以通过命令行输入python --version来检查Python的安装情况。如果输出版本信息,说明安装成功。

3. Python环境设置

3.1 安装集成开发环境(IDE)

常用的Python IDE有PyCharm(社区版免费)、VS Code、Jupyter Notebook等。在本教程中,我们将使用PyCharm进行示例代码的编写。

3.2 安装Python库管理工具pip

pip是Python的包管理工具,用于安装和管理第三方库。可以通过命令行输入pip --version来检查是否已安装。如果没有安装,可以通过Python安装包下载并安装。

安装完成后,使用以下命令更新pip:

pip install --upgrade pip

3.3 安装常用的第三方库

安装常用的第三方库,比如numpypandasmatplotlib等,可以使用以下命令:

pip install numpy pandas matplotlib
4. Python编程入门

4.1 变量与类型

Python中变量不需要显式声明类型,Python会自动推断类型。Python支持多种类型,如下所示:

  • 整形int

    a = 10
  • 浮点型float

    b = 3.14
  • 字符串型str

    c = "Hello, World!"
  • 布尔型bool

    d = True
    e = False
  • 列表list

    f = [1, 2, 3, 4, 5]
  • 字典dict

    g = {"name": "John", "age": 30}
  • 元组tuple

    h = (1, 2, 3, 4, 5)
  • 集合set
    i = {1, 2, 3, 4, 5}

4.2 基本运算符

Python支持多种运算符,包括算术运算符、比较运算符、逻辑运算符等。下面是一些示例:

  • 算术运算符:

    a = 10
    b = 5
    print(a + b)   # 15
    print(a - b)   # 5
    print(a * b)   # 50
    print(a / b)   # 2.0
    print(a % b)   # 0
  • 比较运算符:

    x = 10
    y = 5
    print(x > y)   # True
    print(x < y)   # False
    print(x == y)  # False
    print(x != y)  # True
  • 逻辑运算符:
    a = True
    b = False
    print(a and b)  # False
    print(a or b)   # True
    print(not a)    # False

4.3 条件语句

条件语句用于在满足某个条件时执行特定代码块。Python使用ifelif(else if的缩写)和else关键字实现条件判断。例如:

x = 10
if x > 5:
    print("x大于5")
elif x == 5:
    print("x等于5")
else:
    print("x小于5")

4.4 循环语句

循环语句用于多次执行一段代码,直到满足特定条件为止。Python支持for循环和while循环。例如:

# for循环
for i in range(5):
    print(i)

# while循环
count = 0
while count < 5:
    print(count)
    count += 1

4.5 函数定义与调用

在Python中,可以使用def关键字定义函数。函数定义包括函数名、参数列表和函数体。例如:

def greet(name):
    print(f"Hello, {name}!")

greet("Alice")
greet("Bob")

4.6 异常处理

Python使用tryexceptelsefinally关键字处理程序异常。例如:

try:
    result = 10 / 0
except ZeroDivisionError:
    print("除数不能为零")
else:
    print("结果为:", result)
finally:
    print("执行完毕")
5. Python面向对象编程

5.1 类与对象

在Python中,类用于定义对象的属性和方法。类可以通过class关键字定义。例如:

class Person:
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def greet(self):
        print(f"我是{self.name}, 我{self.age}岁了")

person1 = Person("Alice", 25)
person1.greet()

5.2 继承与多态

继承允许一个类继承另一个类的属性和方法。多态允许不同类的对象通过相同的接口进行操作。例如:

class Animal:
    def __init__(self, name):
        self.name = name

    def speak(self):
        raise NotImplementedError("子类应实现此方法")

class Dog(Animal):
    def speak(self):
        return f"{self.name}汪汪叫"

class Cat(Animal):
    def speak(self):
        return f"{self.name}喵喵叫"

dog = Dog("旺财")
cat = Cat("花花")

print(dog.speak())  # 旺财汪汪叫
print(cat.speak())  # 花花喵喵叫

5.3 特殊方法

Python中的特殊方法(也称为魔术方法)可以通过__xxx__的形式定义,提供类对象的行为实现。例如:

class Rectangle:
    def __init__(self, length, width):
        self.length = length
        self.width = width

    def __str__(self):
        return f"长度:{self.length}, 宽度:{self.width}"

    def __add__(self, other):
        new_length = self.length + other.length
        new_width = max(self.width, other.width)
        return Rectangle(new_length, new_width)

rectangle1 = Rectangle(2, 3)
rectangle2 = Rectangle(4, 5)

print(rectangle1)  # 长度:2, 宽度:3
print(rectangle2)  # 长度:4, 宽度:5

rectangle3 = rectangle1 + rectangle2
print(rectangle3)  # 长度:6, 宽度:5
6. 数据结构

6.1 列表

列表是一种有序的、可变的数据结构,可以存储不同类型的数据。列表使用方括号[]表示。例如:

lst = [1, 2, 3, 4, 5]
print(lst)  # [1, 2, 3, 4, 5]

# 添加元素
lst.append(6)
print(lst)  # [1, 2, 3, 4, 5, 6]

# 访问元素
print(lst[0])  # 1
print(lst[3])  # 4

# 修改元素
lst[0] = 0
print(lst)  # [0, 2, 3, 4, 5, 6]

# 删除元素
del lst[1]
print(lst)  # [0, 3, 4, 5, 6]

# 列表切片
print(lst[1:3])  # [3, 4]
print(lst[2:])   # [4, 5, 6]
print(lst[:3])   # [0, 3, 4]

6.2 元组

元组是一种有序的、不可变的数据结构。元组使用圆括号()表示。例如:

tup = (1, 2, 3, 4, 5)
print(tup)  # (1, 2, 3, 4, 5)

# 访问元素
print(tup[0])  # 1
print(tup[3])  # 4

# 列表切片
print(tup[1:3])  # (2, 3)
print(tup[2:])   # (3, 4, 5)
print(tup[:3])   # (1, 2, 3)

# 元组不能修改
# tup[0] = 0  # TypeError: 'tuple' object does not support item assignment

6.3 字典

字典是一种无序的、可变的数据结构,使用键值对(key-value)存储数据。字典使用花括号{}表示。例如:

dct = {"name": "John", "age": 30, "city": "New York"}
print(dct)  # {'name': 'John', 'age': 30, 'city': 'New York'}

# 访问元素
print(dct["name"])  # John
print(dct["age"])   # 30

# 修改元素
dct["age"] = 31
print(dct["age"])   # 31

# 添加元素
dct["job"] = "Engineer"
print(dct)  # {'name': 'John', 'age': 31, 'city': 'New York', 'job': 'Engineer'}

# 删除元素
del dct["city"]
print(dct)  # {'name': 'John', 'age': 31, 'job': 'Engineer'}

# 遍历字典
for key, value in dct.items():
    print(f"{key}:{value}")
    # name:John
    # age:31
    # job:Engineer

6.4 集合

集合是一种无序的、不重复的数据结构。集合使用花括号{}set()函数表示。例如:

s = {1, 2, 3, 4, 5}
print(s)  # {1, 2, 3, 4, 5}

# 添加元素
s.add(6)
print(s)  # {1, 2, 3, 4, 5, 6}

# 删除元素
s.remove(2)
print(s)  # {1, 3, 4, 5, 6}

# 集合操作
set1 = {1, 2, 3, 4, 5}
set2 = {4, 5, 6, 7, 8}

# 并集
union_set = set1.union(set2)
print(union_set)  # {1, 2, 3, 4, 5, 6, 7, 8}

# 交集
intersection_set = set1.intersection(set2)
print(intersection_set)  # {4, 5}

# 差集
difference_set = set1.difference(set2)
print(difference_set)  # {1, 2, 3}
7. 文件操作

Python提供了多种方法来处理文件。可以使用open()函数打开文件,并使用read()write()等方法读取和写入文件内容。例如:

# 读取文件
with open("example.txt", "r") as file:
    content = file.read()
    print(content)

# 写入文件
with open("example.txt", "w") as file:
    file.write("Hello, World!")

7.1 使用with语句

with语句用于自动管理资源,确保文件在使用后正确关闭。例如:

with open("example.txt", "r") as file:
    print(file.readline())  # 读取第一行
    print(file.readlines())  # 读取所有行

7.2 文件模式

文件模式包括:

  • r:只读模式,用于读取文件。如果文件不存在,将引发FileNotFoundError
  • w:写入模式,用于写入文件。如果文件存在,将覆盖原有内容;如果文件不存在,将创建新文件。
  • a:追加模式,用于写入文件。如果文件存在,将在末尾添加内容;如果文件不存在,将创建新文件。
  • x:独占创建模式,用于写入文件。如果文件存在,将引发FileExistsError;如果文件不存在,将创建新文件。
  • b:二进制模式,用于处理二进制文件。
  • t:文本模式,用于处理文本文件。
8. 数据处理与科学计算

8.1 NumPy

NumPy是Python中用于科学计算的重要库,提供了大量的数学函数和对多维数组的支持。例如:

import numpy as np

# 创建数组
array1 = np.array([1, 2, 3, 4, 5])
print(array1)  # [1 2 3 4 5]

# 数组运算
array2 = np.array([6, 7, 8, 9, 10])
print(array1 + array2)  # [ 7  9 11 13 15]
print(array1 * array2)  # [ 6 14 24 36 50]

# 创建二维数组
matrix = np.array([[1, 2, 3], [4, 5, 6]])
print(matrix)  # [[1 2 3] [4 5 6]]

# 访问元素
print(matrix[0][0])  # 1
print(matrix[1][1])  # 5

# 数组运算
print(matrix * 2)  # [[ 2  4  6] [ 8 10 12]]

8.2 Pandas

Pandas是一个强大的数据分析库,提供了DataFrame数据结构来处理表格数据。例如:

import pandas as pd

# 创建DataFrame
data = {
    "Name": ["Alice", "Bob", "Charlie"],
    "Age": [25, 30, 35],
    "City": ["New York", "Los Angeles", "Chicago"]
}
df = pd.DataFrame(data)
print(df)
#      Name  Age         City
# 0   Alice   25     New York
# 1     Bob   30  Los Angeles
# 2  Charlie   35       Chicago

# 查看数据
print(df.head())  # 查看前5行
print(df.tail())  # 查看后5行

# 过滤数据
print(df[df["Age"] > 30])  # 年龄大于30岁的人
#      Name  Age         City
# 2  Charlie   35       Chicago

8.3 Matplotlib

Matplotlib是一个用于绘制图表的库,提供了多种类型的图表。例如:

import matplotlib.pyplot as plt

# 创建数据
x = [1, 2, 3, 4, 5]
y = [2, 3, 5, 7, 11]

# 绘制线图
plt.plot(x, y)
plt.xlabel("X轴")
plt.ylabel("Y轴")
plt.title("线图示例")
plt.show()

# 绘制柱状图
plt.bar(x, y)
plt.xlabel("X轴")
plt.ylabel("Y轴")
plt.title("柱状图示例")
plt.show()

# 绘制散点图
plt.scatter(x, y)
plt.xlabel("X轴")
plt.ylabel("Y轴")
plt.title("散点图示例")
plt.show()
9. 网络编程

9.1 HTTP请求

Python中可以使用requests库发送HTTP请求。例如:

import requests

# 发送GET请求
response = requests.get("https://www.example.com")
print(response.status_code)  # 200
print(response.text)

# 发送POST请求
response = requests.post("https://www.example.com", data={"key": "value"})
print(response.status_code)
print(response.text)

9.2 异步编程

Python 3.5及以上版本引入了asyncio库来支持异步编程。例如:

import asyncio

async def async_function():
    print("开始执行异步函数")
    await asyncio.sleep(1)  # 模拟异步操作
    print("异步函数执行完毕")

# 运行异步函数
asyncio.run(async_function())
10. 网页爬虫

10.1 使用BeautifulSoup

BeautifulSoup是一个用于解析HTML和XML文档的库。例如:

import requests
from bs4 import BeautifulSoup

# 发送GET请求
response = requests.get("https://www.example.com")
html_content = response.text

# 解析HTML文档
soup = BeautifulSoup(html_content, "html.parser")

# 查找标签
title = soup.title
print(title.string)  # 示例标题

# 查找所有链接
links = soup.find_all("a")
for link in links:
    print(link.get("href"))

10.2 使用Scrapy

Scrapy是一个强大的网络爬虫框架,可以用于构建复杂的爬虫。例如:

import scrapy

class ExampleSpider(scrapy.Spider):
    name = "example"
    start_urls = ["https://www.example.com"]

    def parse(self, response):
        # 解析页面
        title = response.css("title::text").get()
        print(title)

        # 查找链接
        links = response.css("a::attr(href)").getall()
        for link in links:
            print(link)
11. 数据库操作

11.1 使用SQLite

SQLite是一个轻量级的关系型数据库,不需要单独的服务器进程或系统管理员介入。例如:

import sqlite3

# 连接到SQLite数据库
conn = sqlite3.connect("example.db")

# 创建游标对象
cursor = conn.cursor()

# 创建表
cursor.execute("""
CREATE TABLE IF NOT EXISTS users (
    id INTEGER PRIMARY KEY,
    name TEXT NOT NULL,
    age INTEGER NOT NULL
)
""")

# 插入数据
cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ("Alice", 25))
cursor.execute("INSERT INTO users (name, age) VALUES (?, ?)", ("Bob", 30))

# 提交事务
conn.commit()

# 查询数据
cursor.execute("SELECT * FROM users")
rows = cursor.fetchall()
for row in rows:
    print(row)

# 关闭数据库连接
conn.close()

11.2 使用MySQL

MySQL是一个广泛使用的开源关系型数据库管理系统。使用Python连接MySQL可以使用mysql-connector-python库。例如:

import mysql.connector

# 连接到MySQL数据库
conn = mysql.connector.connect(
    host="localhost",
    user="root",
    password="password",
    database="example"
)

# 创建游标对象
cursor = conn.cursor()

# 创建表
cursor.execute("""
CREATE TABLE IF NOT EXISTS users (
    id INT PRIMARY KEY,
    name VARCHAR(255) NOT NULL,
    age INT NOT NULL
)
""")

# 插入数据
cursor.execute("INSERT INTO users (name, age) VALUES (%s, %s)", ("Alice", 25))
cursor.execute("INSERT INTO users (name, age) VALUES (%s, %s)", ("Bob", 30))

# 提交事务
conn.commit()

# 查询数据
cursor.execute("SELECT * FROM users")
rows = cursor.fetchall()
for row in rows:
    print(row)

# 关闭数据库连接
conn.close()
12. Python脚本编写

12.1 自动化任务脚本

编写Python脚本可以帮助我们自动化执行重复性任务。例如,可以编写一个脚本来定期备份文件或目录。

import shutil
import os

# 源文件夹和目标文件夹
source_folder = "/path/to/source"
target_folder = "/path/to/target"

# 创建目标文件夹(如果不存在)
if not os.path.exists(target_folder):
    os.makedirs(target_folder)

# 遍历文件夹中的文件
for file_name in os.listdir(source_folder):
    source_file = os.path.join(source_folder, file_name)
    target_file = os.path.join(target_folder, file_name)

    # 复制文件
    shutil.copy(source_file, target_file)
    print(f"已备份文件 {source_file} 到 {target_file}")

12.2 脚本参数化

可以使用argparse库来处理命令行参数,使脚本更加灵活。例如,编写一个脚本,从命令行接收文件夹路径并备份文件。

import argparse
import shutil
import os

def backup_files(source_folder, target_folder):
    if not os.path.exists(target_folder):
        os.makedirs(target_folder)

    for file_name in os.listdir(source_folder):
        source_file = os.path.join(source_folder, file_name)
        target_file = os.path.join(target_folder, file_name)

        shutil.copy(source_file, target_file)
        print(f"已备份文件 {source_file} 到 {target_file}")

if __name__ == "__main__":
    parser = argparse.ArgumentParser(description="文件备份脚本")
    parser.add_argument("source_folder", type=str, help="源文件夹路径")
    parser.add_argument("target_folder", type=str, help="目标文件夹路径")
    args = parser.parse_args()

    backup_files(args.source_folder, args.target_folder)

使用命令行运行上述脚本:

python backup_script.py /path/to/source /path/to/target
13. 总结

Python是一种强大且灵活的编程语言,适合各种应用场景,如网站开发、数据分析、科学计算等。通过本教程的学习,你可以掌握Python的基本语法、数据结构、文件操作、网络编程和数据库操作等重要概念和技术。希望这些知识能够帮助你更好地使用Python进行编程。

参考资料中的代码如下:

# Python基础示例
print("Hello, World!")  # 输出Hello, World!

# 变量类型
a = 10
b = 3.14
c = "Python"
d = True
e = ["apple", "banana", "cherry"]
f = {"name": "John", "age": 30}
g = (1, 2, 3)
h = {1, 2, 3}

# 条件语句
x = 5
if x > 10:
    print("x大于10")
elif x == 10:
    print("x等于10")
else:
    print("x小于10")

# 循环语句
for i in range(5):
    print(i)

print()

count = 0
while count < 5:
    print(count)
    count += 1

# 函数定义
def greet(name):
    print(f"Hello, {name}!")

greet("Alice")

# 异常处理
try:
    result = 10 / 0
except ZeroDivisionError:
    print("除数不能为零")
# 使用requests库发送HTTP请求
import requests

response = requests.get("https://www.example.com")
print(response.status_code)
print(response.text)
# 使用BeautifulSoup解析HTML文档
import requests
from bs4 import BeautifulSoup

response = requests.get("https://www.example.com")
html_content = response.text

soup = BeautifulSoup(html_content, "html.parser")
title = soup.title
print(title.string)

links = soup.find_all("a")
for link in links:
    print(link.get("href"))
# 使用Scrapy构建网络爬虫
import scrapy

class ExampleSpider(scrapy.Spider):
    name = "example"
    start_urls = ["https://www.example.com"]

    def parse(self, response):
        title = response.css("title::text").get()
        print(title)

        links = response.css("a::attr(href)").getall()
        for link in links:
            print(link)
打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP