python作业题百度网盘,python123作业答案

大家好,小编来为大家解答以下问题,python作业题百度网盘,python123作业答案,今天让我们一起来看看吧!

完整项目分享:
链接: https://pan.baidu.com/s/1CTMOgLYteLrWRaRnouB0SQ?pwd=12hf 提取码: 12hf
(如果这个项目帮助到你了,麻烦点个赞,谢谢)

1.实现功能:

1.进行简单的日常生活聊天(首先根据输入寻找对应答案,如果未找到对应答案,就结合从百度百科上爬取下的内容进行回答)
2.关于具体电影和音乐话题的聊天(联系上文语境实现关键词双重查找)
附加部分
为机器人增加了语音播报功能
实现了一个简单的GUI,实现了交互功能
机器人对话均为中文对话

2.功能演示

日常聊天部分:

1.进行简单的对话

点击开始按钮,在内部对程序进行初始化
在这里插入图片描述

将想要输入的部分输入到发送框中,然后点击发送
在这里插入图片描述

2.对于特定的关键词知道进行搜索

在这里插入图片描述

当然,如果想要的数据更精确,也可以直接行驶查询功能
在这里插入图片描述

特定话题部分:

流程:
首先需要输入“聊电影”
然后利用特定的输入来激活到某个更具体的话题
比如输入的“知道恋恋笔记本这部电影吗?”,“知道陈可辛吗?”,然后就可以就这个部分进行话题的探讨
需要退出具体话题的聊天,可以直接输入exit实现退出,返回到日常生活中的聊天。

首先是激活到对应的具体话题部分

我们先输入“聊电影”
然后再看“激活特定话题用关键词.txt”文件中的内容,选择一个输入
这里输入的是“你知道陈可辛吗?”就正式进入这个话题下的聊天了
在这里插入图片描述

找到对应部分后,就可以输入对话python简单图案代码。这里利用了双层的关键词查找和联系上下问语境
在这里插入图片描述

双层关键词
在这里插入图片描述

联系上下文语境
在这里插入图片描述

前面先聊到“梁家辉”,此时的话题就记住了关键词“梁家辉”,然后再问出生日期,聊天机器人就会在“梁家辉”对应的词条下面寻找。后来又聊到了“陈可辛”,此时的语境就会切换成陈可辛,你再问机器人,机器人就会在结合陈可辛的语境进行回答。

3.实现过程:

实现所用到库

jieba: 用于中文分词。方便将对话输入拆分关键词,便于查找
tkinter:用于实现GUI交互界面
json:用于读取json格式的语料库文件
pyttsx3:用于实现机器人的语音播报

实现思路:

整体思路是结合预料库进行正则匹配。
首先是整个字符串进行匹配,如果找到就可以直接进行输出
然后是关键词逐个匹配,在上一种情况没有匹配的情况下,将输入的话进行关键词的拆分和组合,再进行关键词的匹配。

扩展部分思路
这部分是结合语境以及关键词多重匹配
结合了具体话题的语料库的性质。
这个语料库的关键词分为三层。
第一层适用于我们激活到更加具体的话题,比如说提问“知道陈可辛吗?”,这一整句话就是第一层关键词,保证回答不会跳出这个话题。
第二层关键词就适用于语境了,每次找到新回答后,这个语境关键词都会被更新。
第三层关键词用于查找具体的回答。
结合语境:
每次找到新回答后就会更新语境,下一次再要寻找回答时,会优先匹配之前的语境下的第三层关键词,如果匹配成功了,那就直接输出。如果没有在之前的语境关键词下匹配成功。就跳转到使用关键词的多重匹配。
关键词多重匹配:
利用jieba库对输入的话进行关键词拆分和组合,得到我们实际想知道的关键词的所有可能。
先用所有的关键词可能匹配第二层关键词,如果匹配成功了就再匹配这个语境关键词下的所有第三层关键词,一旦匹配成功就可以输出了。

举例
输入“梁家辉主要成就”
将关键词拆分组合成“梁家辉”“梁家辉成就”,“梁家辉主要”,“梁家梁家辉成就”,“梁家梁家辉主要”,“梁家梁家辉”,“梁家成就”,“梁家主要成就”,“梁家主要”。
利用这些关键词逐个匹配第二层关键词,发现“梁家辉”这个关键词匹配成功了
在“梁家辉”这个语境关键词下,再次利用所有的关键词可能匹配第三层关键词,发现匹配成功了“主要成就”,就将对应结果输出了。

实现所用函数的解释:

query(content)
输入:要查询的词条
输出:查询的结果
功能:爬取百度百科content的搜索内容
StrSplit(String)
输入:要拆分的字符串
输出:所有可能字符子串的数组
功能:将输入的内容进行关键词拆分和组合,返回形成字符串数组。
query_find(String)
输入:要检查的字符串
输出:返回是否符合查找的格式,和查询的结果
功能:检查输入的String是不是符合“知道xx吗”的形式,如果是,就调用query进行查找,并且更改返回值。
MatchSiple(path, String)
输入:语料库的路径,要查询的字符串
输出:返回是否找到结果以及结果
功能:检查String是否在path对应的文件内容中有直接的完全符合的匹配,如果有就修改返回值
MatchHeight(path, String_lt)
输入:语料库的路径,分割好后的字符串数组
输出:是否查询到结果,查询的结果
功能:逐个检查String_lt字符串数组中的字符串是否在path对应文件有完全的匹配,如有有匹配,就对应答案该返回值。
ai_movie_MatSiple(data,String oeder)
与MatchSiple(path,String)类似,只是使用的语料库切换成了具体话题的语料库。
ai_movie_MatchHeight(data, String_lt,order,name):同上。
ai_films_Matchname(data,String):
输入:具体话题的语料库,输入的字符串
输出:查询的结果,是否查询到结果,查询到的第一个关键词
功能:确定好第一个关键词。
films(engine,file,string):
输入:语音播报,打开的语料库文件,要检测的字符串
输出:无返回值,直接将内容输出到GUI上,同时进行语音播报
功能:根据前后全局变量的信息,有针对性调用前面所说的函数,找到对应的结果。
chat_bot(String):
输入:要询问的部分
输出: 无返回值,直接将内容输出到GUI上,同时进行语音播报。
功能:根据几个全局变量的信息,有针对性的调用上述函数,找到最终的结果
send():
这个函数是被按钮“发送”所调用的,会调用chat_bot()函数,寻找返回的字符串,同时将输入的内容有人插入到GUI的文本框中。
begin():
对所有的信息进行初始化,这个函数是由“开始”按钮所调用的

代码中全局变量的解释

global tag1:用于表示当前机器人的状态是不是在“聊电影”这个特殊的话题上
global tag2:用于表示当前机器人的状态是不是在“聊音乐”这个特殊的话题上
global name:用于记录在“聊电影”和“聊音乐”上的第一个关键词
global path:用于记录日常聊天的语料库的路径
global engine:用于记录语音播报
global file1:记录“聊电影”的语料库文件
global file2:记录“聊音乐”的语料库文件
global data:记录打开的具体话题对应文件转化成的dirt
global ord:记录在“聊电影”或者“聊音乐”这两个具体部分中,第一个关键词对应的位置。还是方便后续的查找

##4.实验总结:

本次实验的主题思路是实现关键词的提取和匹配,根据已经有的语料库进行针对性的回答。
在一般的完全匹配上,增加了关键词的拆分重新组合,增加了结合语境,增加了关键词双重匹配,增加了不知道结果时可以从百度百科上爬取答案。同时增加了交互界面语音播报
实现了可以简单的一问一答,具体话题下的更具体的回答。
但是由于语料库的欠缺,在实现具体话题下问答时需要用特殊的话来进行激活,这一点是有待改进。同时这次大作业,借鉴了网络上的一些思路,表示感谢。

import tkinter
import tkinter as tk
from tkinter import scrolledtext
import jieba
import urllib.request
import urllib.parse
from lxml import etree
import json
import pyttsx3

# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~全局变量~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
global tag1
global tag2
global name
global path
global engine
global file1
global file2
global data
global ord
tag1 = 0
tag2 = 0
name = None
# 标记两个tag,一个tag表示当前的选择是一般性回答还是film,另一个tag是在film中表示是不是第一次使用film的库
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


# ~~~~~~~~~~~~~~~~~~~~~~~~~~~日常对话部分查找~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def query(content):
    # 请求地址
    url = 'https://baike.baidu.com/item/' + urllib.parse.quote(content)
    # 请求头部
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36'
    }
    # 利用请求地址和请求头部构造请求对象
    req = urllib.request.Request(url=url, headers=headers, method='GET')
    # 发送请求,获得响应
    response = urllib.request.urlopen(req)
    # 读取响应,获得文本
    text = response.read().decode('utf-8')
    # 构造 _Element 对象
    html = etree.HTML(text)
    # 使用 xpath 匹配数据,得到匹配字符串列表
    sen_list = html.xpath('//div[contains(@class,"lemma-summary") or contains(@class,"lemmaWgt-lemmaSummary")]//text()')
    # 过滤数据,去掉空白
    sen_list_after_filter = [item.strip('\n') for item in sen_list]
    # 将字符串列表连成字符串并返回
    return ''.join(sen_list_after_filter)

def query_find(String):
    back = None
    find = 0
    if '知道' in String:                      # 符合”知道XX吗“的格式,直接调用query对结果进行爬虫
        find = 1
        f1 = String.split('知道')
        f1 = f1[1].split('吗')
        back = query(f1[0])
        if len(back) < 2:
            back = '这个小蜗也不知道哎'
    lt_ms = [back, find]
    return lt_ms

def StrSplit(String):
    """
    Decompose the string into a list           # 将字符串分解为一个列表
    :param String: The string to be decomposed # 要分解的字符串
    :return: String_lt                         # 分解后的字符串列表
    """
    String_lt = jieba.lcut(String, cut_all=True)    # 要引入jieba库
    String1 = jieba.lcut(String, cut_all=True)
    String2 = jieba.lcut(String, cut_all=True)
    String3 = jieba.lcut(String, cut_all=True)
    String3.append('')
    for Str1 in String1:
        String_lt.append(Str1)
        String2.remove(Str1)
        for Str2 in String2:
            String_lt.append(Str2)                  # 要添加分出来的关键词
            try:
                String3.remove(Str1)
            except:
                pass
            try:
                String3.remove(Str2)
            except:
                pass
            for Str3 in String3:
                String_lt.append(Str3)
                String_lt.append(Str1 + Str2 + Str3)            # 添加组合成的关键词
    String_lt = sorted(String_lt, reverse=True)
    return String_lt

def MatchSiple(path, String):
    """
    Matches the dictionary to a single string  # 将字典匹配到单个字符串
    :param path: The dictionary to match       # 匹配的字典
    :param String: The string to match         # 要匹配的字符串
    :return: lt_ms                             # 匹配结果与判断(1有/0无)的列表
    """
    errow_matchsplit = 0
    back = None

    f1 = String.split(':')[0]
    if f1 == '查询':
        errow_matchsplit = 1
        back = query(String.split(':')[1])
        lt_ms = [back, errow_matchsplit]
        return lt_ms

    with open(path, 'r', encoding='utf-8') as f:     # 注意编码
        while errow_matchsplit == 0:
            f1 = f.readline().split('\n')[0]
            f2 = f.readline().split('\n')[0]
            f3 = f.readline()
            if String == f1:
                back = f2
                errow_matchsplit = 1
                break
            if f1 == '' or f2 == '':
                break
    lt_ms = [back, errow_matchsplit]
    if errow_matchsplit == 0:
        lt_ms = query_find(String)
    return lt_ms

def MatchHeight(path, String_lt):
    """
    Matches the dictionary with a list of strings # 用字符串列表匹配字典
    :param path: The dictionary to match          # 匹配的字典
    :param String_lt: List of strings to match    # 要匹配的字符串列表
    :return: lt_mh                                # 匹配结果与判断(1有/0无)的列表
    """
    errow_matchheight = 0
    back = None
    with open(path, 'r', encoding='utf-8') as f:     # 注意编码
        while errow_matchheight == 0:
            f1 = f.readline().split('\n')[0]
            f2 = f.readline().split('\n')[0]
            f3 = f.readline()
            for String in String_lt:
                if String == f1:
                    back = f2
                    errow_matchheight = 1
                    break
            if f1 == '' or f2 == '':
                break
    lt_mh = [back, errow_matchheight]
    return lt_mh

# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

def study(path, study_start, study_end):
    """
    Open the dictionary and write the match statement and the match result # 打开字典并编写匹配语句和匹配结果
    :param path: The dictionary to open                                    # 要查的字典
    :param study_start: Dictionary matching statements                     # 词典匹配语句
    :param study_end: The dictionary returns the result                    # 字典返回结果
    :return: None                                                          # 无返回
    """
    with open(path, 'a', encoding='utf-8') as f:     # 注意编码
        f.write(study_start+'\n')
        f.write(study_end+'\n')
        f.write('\n')

# ~~~~~~~~~~~~~~~~~~~~~~~~~~~具体话题查找~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def ai_movie_MatchSiple(data, String, order):
    errow_movie_match = 0
    back = None
    name = None
    f1 = String.split(':')[0]
    if f1 == '查询':
        errow_matchsplit = 1
        back = query(String.split(':')[1])
        lt_ms = [back, errow_matchsplit,name]
        return lt_ms
    for i in  range(len(data[order]['messages'])):
        if data[order]['messages'][i]['message'] == String:
            back = data[order]['messages'][i+1]['message']
            name = data[order]['messages'][i+1]['attrs'][0]['name']
            errow_movie_match = 1
            break
    lt_ms = [back, errow_movie_match, name]
    return lt_ms

def ai_movie_MatchHeight(data, String_lt, order, name):
    errow_movie_matchH = 0
    back = None
    find = 0
    for i in range(len(data[order]['messages'])):                               # 优先根据结果进行检查
        if errow_movie_matchH == 1:
            break
        if len(data[order]['messages'][i]) == 2:
            for String in String_lt:
                if errow_movie_matchH == 1:
                    break
                # print(String, '   ', data[order]['messages'][i]['attrs'][0]['name'])
                for j in range(len(data[order]['messages'][i]['attrs'])):       #判断是否普找到
                    if String == data[order]['messages'][i]['attrs'][j]['name']:
                        find = 1
                        break
                if find == 1:
                    for j in range(len(data[order]['messages'][i]['attrs'])):
                        if errow_movie_matchH == 1:
                            break
                        for String in String_lt:
                            if String == data[order]['messages'][i]['attrs'][j]['attrname']:
                                back = data[order]['messages'][i]['attrs'][j]['name']+','+data[order]['messages'][i]['attrs'][j]['attrname']+':'+data[order]['messages'][i]['attrs'][j]['attrvalue']
                                name = data[order]['messages'][i]['attrs'][j]['name']
                                errow_movie_matchH = 1
                                break

    for i in range(len(data[order]['messages'])):                               # 优先根据结果进行检查
        if errow_movie_matchH == 1:
            break
        if len(data[order]['messages'][i]) == 2:
            for String in String_lt:
                #if len(data[order]['messages'][i]['attrs'][0]) == 1:
                         #说明有不止一个attr
                for j in range(len(data[order]['messages'][i]['attrs'])):
                    if String == data[order]['messages'][i]['attrs'][j]['attrname']:
                        if name == data[order]['messages'][i]['attrs'][j]['name']:      # 首先对name 进行检验,不过这时候的name要换成String,进行三重检测
                            back = data[order]['messages'][i]['attrs'][j]['name']+','+data[order]['messages'][i]['attrs'][j]['attrname']+':'+data[order]['messages'][i]['attrs'][j]['attrvalue']
                            errow_movie_matchH = 1
                            break

    for i in range(len(data[order]['messages'])):
        if errow_movie_matchH == 1:
            break
        if len(data[order]['messages'][i]) == 2:
            for String in String_lt:
                for j in range(len(data[order]['messages'][i]['attrs'])):
                    if String == data[order]['messages'][i]['attrs'][j]['attrname']:
                        back = data[order]['messages'][i]['attrs'][j]['name']+','+data[order]['messages'][i]['attrs'][j]['attrname']+':'+data[order]['messages'][i]['attrs'][j]['attrvalue']
                        name = data[order]['messages'][i]['attrs'][j]['name']
                        errow_movie_matchH = 1
                        break
    lt_mh = [back, errow_movie_matchH, name]
    return lt_mh

def ai_films_Matchname(data,String):
    errow_matchsplit = 0
    back = 0
    name = None
    for i in range(149):
            if data[i]['messages'][0]['message'] == String:
                errow_matchsplit = 1
                name = data[i]['messages'][1]['attrs'][0]['name']
                back = i
                break
    lt_ms = [back, errow_matchsplit, name]
    return lt_ms

def films(engine, file,String):                        ##聊电影对应的模块
    global tag1
    global tag2
    global name
    global data
    global ord
    if tag2 == 0:                                 ##说明刚刚进入到这个模块当中
        data = json.load(file)
        order = ai_films_Matchname(data, String)
        name = order[2]
        ord = order[0]
        t.insert('end', '小蜗:'+data[order[0]]['messages'][1]['message']+'\n')
        engine.say(data[order[0]]['messages'][1]['message'])
        engine.runAndWait()
        tag2 = 1

    elif String == 'exit':
        tag2 = 0
        tag1 = 0
    else:
        a1 = ai_movie_MatchSiple(data=data, String=String, order=ord)
        show = a1[0]
        errow_matchsimple = a1[1]
        if errow_matchsimple == 0:  # 说明没有找到直接相匹配的,关键词进行重组,查找对应的关键词
            String_lt = StrSplit(String=String)
            a2 = ai_movie_MatchHeight(data=data, String_lt=String_lt, order=ord, name=name)
            show = a2[0]
            errow_matchhight = a2[1]
            if errow_matchhight == 0:
                t.insert('end', '小蜗:小蜗不知道这个细节唉😔'+'\n')
                engine.say("小蜗不知道这个细节唉")
                engine.runAndWait()
            else:
                name = a2[2]
                t.insert('end', '小蜗:'+ show+'\n')
                engine.say(show)
                engine.runAndWait()
        else:
            name = a1[2]
            t.insert('end', '小蜗:' + show + '\n')
            engine.say(show)
            engine.runAndWait()
    return
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

# ~~~~~~~~~~~~~~~~~~~~~相当于main函数,总调度~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def chat_bot(String):
    global  tag1
    global  tag2
    global engine
    global file1
    global file2
    global path
    if tag1 == 0:               #标志现在是在正常的聊天当中
        if String == '聊电影':
            tag1 = 1
            return
        elif String == '聊音乐':
            tag2 = 2
            return
        else:
            a1 = MatchSiple(path=path, String=String)
            show = a1[0]
            errow_matchsimple = a1[1]
            if errow_matchsimple == 0:
                String_lt = StrSplit(String=String)  # 对关键词全部进行重新组合
                a2 = MatchHeight(path=path, String_lt=String_lt)
                show = a2[0]
                errow_matchhight = a2[1]
                if errow_matchhight == 0:
                    t.insert('end', '小蜗: 小蜗不知道怎么回答哎'+'\n')
                    engine.say("小蜗不知道怎么回答哎")
                    engine.runAndWait()
                else:
                    t.insert('end', '小蜗:'+show+'\n')
                    engine.say(show)
                    engine.runAndWait()
            else:
                t.insert('end', '小蜗:'+show+'\n')
                engine.say(show)
                engine.runAndWait()
    elif tag1 == 1:
        films(engine=engine, file=file1, String=String)
    elif tag2 == 2:
        films(engine=engine, file=file2, String=String)
    return
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

# ~~~~~~~~~~~~~~~~~~~~~~按钮对应函数~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
def send():
    val = e.get()
    e.delete(0, tkinter.END)
    t.insert('end', '主人:' + val + '\n')  # 将要输出的内容插入到文本框中
    chat_bot(String=val)
    t.see(tkinter.END)

def begin():                                    #默认加载学习模块
    global engine
    global path
    global tag1
    tag1 = 0
    path = r'ai.txt'
    engine = pyttsx3.init()
    voices = engine.getProperty('voices')               # 音色
    engine.setProperty('voice', "com.apple,speech.synthesis.voice.meijia")
    rate = engine.getProperty('rate')                   # 速率
    engine.setProperty('rate', 180)
    volume = engine.getProperty('volume')               # 音量
    engine.setProperty('volume', 1.0)
    global file1
    global file2
    file1 = open('file.json', 'r', encoding='utf8')
    file2 = open('music.json', 'r', encoding='utf8')
    # t.insert('end', '-' * 10 + '程序开始' + '-' * 10 + '\n')
    t.insert('end', '小蜗: 程序开始了哦'+'\n')
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

# ~~~~~~~~~~~~~~~GUI部分~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
window = tk.Tk()
window.title('小蜗机器人')
window.geometry('800x200')

l1 = tk.Label(window, text='聊天', font=('Arial', 12), width=15,
             height=1)
l2 = tk.Label(window, text='发送框', font=('Arial', 12), width=15,
             height=1)
# 直接传入部分对应输出部分
e = tk.Entry(window, width=100)
t = scrolledtext.ScrolledText(window, height=10, width=100)

be = tk.Button(window,text='开始', font=('Arial', 12), width =10,
               height=1, command=begin)

b = tk.Button(window, text='发送', font=('Arial', 12), width=10,
              height=1, command=send)
# 界面布置
l1.grid(row=0, column=0)
l2.grid(row=1, column=0)
e.grid(row=1, column=1)
t.grid(row=0, column=1)
be.grid(row=2, column=0)
b.grid(row=2, column=1)
window.mainloop()
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

E:. │ 1.txt │ ├─千锋Python教程:第01章 第一个Python程序与数据存储及数据类型(9集) │ │ .DS_Store │ │ │ ├─code │ │ 1、数据存储.txt │ │ 2、第一个python程序.py │ │ 3、注释.py │ │ 4、输出与输入.py │ │ 5、Python数据类型.py │ │ 6、标识符.py │ │ 7、变量与常量.py │ │ │ ├─file │ │ │ MindManager_64bit_17.2.208.exe │ │ │ Python安装.pdf │ │ │ Python概述.pdf │ │ │ submit 2.0.rar │ │ │ │ │ ├─pycharm专业版 │ │ │ pycharm-professional-2017.2.3.exe │ │ │ Pycharm.txt │ │ │ │ │ └─python3.6 │ │ └─windows │ │ python-3.6.0-amd64.exe │ │ │ └─video │ 千锋Python教程:01.python概述和工具的安装.mp4 │ 千锋Python教程:02.数据存储与二进制操作1.mp4 │ 千锋Python教程:03.数据存储与二进制操作2.mp4 │ 千锋Python教程:04.第一个Python程序与注释及输入输出.mp4 │ 千锋Python教程:05.Python数据类型,标识符,变量与常量以及Number数据类型1.mp4 │ 千锋Python教程:06.Python数据类型,标识符,变量与常量以及Number数据类型2.mp4 │ 千锋Python教程:07.Python数据类型,标识符,变量与常量以及Number数据类型3.mp4 │ 千锋Python教程:08.数学功能与数字类型转换的使用1.mp4 │ 千锋Python教程:09.数学功能与数字类型转换的使用2.mp4 │ ├─千锋Python教程:第02章 运算符与表达式(7集) │ │ .DS_Store │ │ │ ├─code │ │ 1、运算符与表达式.py │ │ 2、运算符与表达式.py │ │ │ └─video │ 千锋Python教程:10.算术&赋值&位&关系运算符与表达式1.mp4 │ 千锋Python教程:11.算术&赋值&位&关系运算符与表达式2.mp4 │ 千锋Python教程:12.逻辑运算符与表达式1.mp4 │ 千锋Python教程:13.逻辑运算符与表达式2.mp4 │ 千锋Python教程:14.成员&身份运算符&字符串1.mp4 │ 千锋Python教程:15.成员&身份运算符&字符串2.mp4 │ 千锋Python教程:16.成员&身份运算符&字符串3.mp4 │ ├─千锋Python教程:第03章 字符串&布尔&空值(7集) │ │ .DS_Store │ │ │ ├─code │ │ 1、String(字符串).py │ │ 2、String的内置函数.py │ │ 3、布尔值和空值.py │ │ 4、变量的类型问题.py │ │ │ └─video │ 千锋Python教程:17.运算符&字符串1.mp4 │ 千锋Python教程:18.运算符&字符串2.mp4 │ 千锋Python教程:19.字符串的使用1.mp4 │ 千锋Python教程:20.字符串的使用2.mp4 │ 千锋Python教程:21.字符串的使用3.mp4 │ 千锋Python教程:22.字符串&布尔值&空值&变量的类型问题1.mp4 │ 千锋Python教程:23.字符串&布尔值&空值&变量的类型问题2.mp4 │ ├─千锋Python教程:第04章 列表&元组&流程控制语句(8集) │ │ .DS_Store │ │ │ ├─code │ │ 1、list(列表).py │ │ 2、列表方法.py │ │ 3、浅拷贝与深拷贝.py │ │ 4、tuple(元组).py │ │ 5、条件控制语句.py │ │ 6、循环语句(while).py │ │ 7、循环语句(for).py │ │ 8、pass语句&continue;语句与break语句.py │ │ │ └─video │ 千锋Python教程:24.列表的使用及深浅拷贝1.mp4 │ 千锋Python教程:25.列表的使用及深浅拷贝2.mp4 │ 千锋Python教程:26.列表的使用及深浅拷贝3.mp4 │ 千锋Python教程:27.深浅拷贝&元组&条件判断语句1.mp4 │ 千锋Python教程:28.深浅拷贝&元组&条件判断语句2.mp4 │ 千锋Python教程:29.循环语句&关键字 break&pass;&continue1;.mp4 │ 千锋Python教程:30.循环语句&关键字 break&pass;&continue2;.mp4 │ 千锋Python教程:31.循环语句&关键字 break&pass;&continue3;.mp4 │ ├─千锋Python教程:第05章 字典&集合&类型转换&turtle;(1集) │ │ .DS_Store │ │ │ ├─code │ │ 1、dict(字典).py │ │ 2、set.py │ │ 3、类型转换.py │ │ │ └─video │ 千锋Python教程:32.字典&集合&类型转换&turtle1;.mp4 │ ├─千锋Python教程:第06章 函数与高阶函数(7集)) │ │ .DS_Store │ │ │ ├─code │ │ 10、函数也是一种数据.py │ │ 11、匿名函数.py │ │ 12、map&reduce;.py │ │ 13、filter.py │ │ 14、sorted.py │ │ 15、作用域.py │ │ 16、体现作用域.py │ │ 17、修改全局变量.py │ │ 18、修改嵌套作用域中的变量.py │ │ 1、函数概述.py │ │ 2、最简单的函数(无参无返回值).py │ │ 3、函数的参数.py │ │ 4、函数的返回值.py │ │ 5、传递参数.py │ │ 6、关键字参数.py │ │ 7、默认参数.py │ │ 8、不定长参数.py │ │ 9、多个返回值.py │ │ │ └─video │ 千锋Python教程:33.函数概述.mp4 │ 千锋Python教程:34.函数的基本使用1.mp4 │ 千锋Python教程:35.函数的基本使用2.mp4 │ 千锋Python教程:36.匿名函数&高阶函数 map&reduce1;.mp4 │ 千锋Python教程:37.匿名函数&高阶函数 map&reduce2;.mp4 │ 千锋Python教程:38.高阶函数 filter&sorted;.mp4 │ 千锋Python教程:39.作用域&修改变量作用域.mp4 │ ├─千锋Python教程:第07章 闭包&装饰器(5集) │ │ .DS_Store │ │ │ ├─code │ │ 10、多个装饰器.py │ │ 11、装饰器使用场景.py │ │ 12、计数函数执行次数.py │ │ 13、retry装饰器.py │ │ 1、变量的作用域链.py │ │ 2、利用闭包突破作用域链.py │ │ 3、装饰器概念.py │ │ 4、简单装饰器.py │ │ 5、复杂装饰器.py │ │ 6、使用@符号装饰.py │ │ 7、通用装饰器.py │ │ 8、参数的装饰器.py │ │ 9、计算程序运行时间.py │ │ │ └─video │ 千锋Python教程:40.闭包&装饰器1.mp4 │ 千锋Python教程:41.闭包&装饰器2.mp4 │ 千锋Python教程:42.闭包&装饰器3.mp4 │ 千锋Python教程:43.装饰器的使用1.mp4 │ 千锋Python教程:44.装饰器的使用2.mp4 │ ├─千锋Python教程:第08章 迭代器&生成器&偏函数(6集) │ 千锋Python教程:45.可迭代对象&列表生成式&生成器1.mp4 │ 千锋Python教程:46.可迭代对象&列表生成式&生成器2.mp4 │ 千锋Python教程:47.可迭代对象&列表生成式&生成器3.mp4 │ 千锋Python教程:48.斐波拉契数列&迭代器.mp4 │ 千锋Python教程:49.杨辉三角&偏函数&模块概述1.mp4 │ 千锋Python教程:50.杨辉三角&偏函数&模块概述2.mp4 │ ├─千锋Python教程:第09章 模块&包&常用模块&三方模块(14集) │ 千锋Python教程:51.系统模块&自定义模块&包1.mp4 │ 千锋Python教程:52.系统模块&自定义模块&包2.mp4 │ 千锋Python教程:53.系统模块&自定义模块&包3.mp4 │ 千锋Python教程:54.time 模块1.mp4 │ 千锋Python教程:55.time 模块2.mp4 │ 千锋Python教程:56.datetime&calendar;&collections1;.mp4 │ 千锋Python教程:57.datetime&calendar;&collections2;.mp4 │ 千锋Python教程:58.collections&uuid;&base64;模块1.mp4 │ 千锋Python教程:59.collections&uuid;&base64;模块2.mp4 │ 千锋Python教程:60.collections&uuid;&base64;模块3.mp4 │ 千锋Python教程:61.base64&hashlib;&hmac;模块1.mp4 │ 千锋Python教程:62.base64&hashlib;&hmac;模块2.mp4 │ 千锋Python教程:63.itertools 模块&三方模块的安装&pillow; 模块1.mp4 │ 千锋Python教程:64.itertools 模块&三方模块的安装&pillow; 模块2.mp4 │ ├─千锋Python教程:第10章 面向对象(26集) │ 千锋Python教程:65.堆和栈&面向对象思想概述1.mp4 │ 千锋Python教程:66.堆和栈&面向对象思想概述2.mp4 │ 千锋Python教程:67.堆和栈&面向对象思想概述3.mp4 │ 千锋Python教程:68.创建类&对象&对象的方法1.mp4 │ 千锋Python教程:69.创建类&对象&对象的方法2.mp4 │ 千锋Python教程:70.类属性&对象属性&构造方法&析构方法&访问权限1.mp4 │ 千锋Python教程:71.类属性&对象属性&构造方法&析构方法&访问权限2.mp4 │ 千锋Python教程:72.类属性&对象属性&构造方法&析构方法&访问权限3.mp4 │ 千锋Python教程:73.@property 装饰器&__slots__限制&单例概述1.mp4 │ 千锋Python教程:74.@property 装饰器&__slots__限制&单例概述2.mp4 │ 千锋Python教程:75.单例的三种实现方式&__repr__&__str__&继承概述1.mp4 │ 千锋Python教程:76.单例的三种实现方式&__repr__&__str__&继承概述2.mp4 │ 千锋Python教程:77.继承的实现&继承体系&栈和队列&python2;.2之前的继承体系1.mp4 │ 千锋Python教程:78.继承的实现&继承体系&栈和队列&python2;.2之前的继承体系2.mp4 │ 千锋Python教程:79.继承的实现&继承体系&栈和队列&python2;.2之前的继承体系3.mp4 │ 千锋Python教程:80.两种继承体系的区别.mp4 │ 千锋Python教程:81.python2.3-2.7的集成体系&py3;的继承体系&多态1.mp4 │ 千锋Python教程:82.python2.3-2.7的集成体系&py3;的继承体系&多态2.mp4 │ 千锋Python教程:83.Mixin&运算符重载&属性监听&枚举类1.mp4 │ 千锋Python教程:84.Mixin&运算符重载&属性监听&枚举类2.mp4 │ 千锋Python教程:85.Mixin&运算符重载&属性监听&枚举类3.mp4 │ 千锋Python教程:86.垃圾回收机制&类装饰器&魔术方法&人射击子弹案例1.mp4 │ 千锋Python教程:87.垃圾回收机制&类装饰器&魔术方法&人射击子弹案例2.mp4 │ 千锋Python教程:88.垃圾回收机制&类装饰器&魔术方法&人射击子弹案例3.mp4 │ 千锋Python教程:89.邮件&短信发送1.mp4 │ 千锋Python教程:90.邮件&短信发送2.mp4 │ ├─千锋Python教程:第11章 银行操作系统&tkinter; 界面(14集) │ 千锋Python教程:100.Entry控件&其他控件使用演示1.mp4 │ 千锋Python教程:101.Entry控件&其他控件使用演示2.mp4 │ 千锋Python教程:102.其他控件使用演示.mp4 │ 千锋Python教程:103.其他控件使用演示1.mp4 │ 千锋Python教程:104.其他控件使用演示2.mp4 │ 千锋Python教程:91.贪吃蛇演示&银行操作系统1.mp4 │ 千锋Python教程:92.贪吃蛇演示&银行操作系统2.mp4 │ 千锋Python教程:93.贪吃蛇演示&银行操作系统3.mp4 │ 千锋Python教程:94.银行操作系统.mp4 │ 千锋Python教程:95.银行操作系统1.mp4 │ 千锋Python教程:96.银行操作系统2.mp4 │ 千锋Python教程:97.银行操作系统&GUI;概述&tkinter; 概述1.mp4 │ 千锋Python教程:98.银行操作系统&GUI;概述&tkinter; 概述2.mp4 │ 千锋Python教程:99.tkinter组件之 label&button;.mp4 │ ├─千锋Python教程:第12章 异常处理&代码调试&IO;编程&目录遍历(14集) │ 千锋Python教程:105.错误处理1.mp4 │ 千锋Python教程:106.错误处理2.mp4 │ 千锋Python教程:107.代码调试1.mp4 │ 千锋Python教程:108.代码调试2.mp4 │ 千锋Python教程:109.单元测试1.mp4 │ 千锋Python教程:110.单元测试2.mp4 │ 千锋Python教程:111.树状目录层级演示&文档测试&读文件1.mp4 │ 千锋Python教程:112.树状目录层级演示&文档测试&读文件2.mp4 │ 千锋Python教程:113.写文件&编码与解码&StringIO;与B ytesIO1.mp4 │ 千锋Python教程:114.写文件&编码与解码&StringIO;与B ytesIO2.mp4 │ 千锋Python教程:115.os模块&数据持久化文件操作1.mp4 │ 千锋Python教程:116.os模块&数据持久化文件操作2.mp4 │ 千锋Python教程:117.目录遍历1.mp4 │ 千锋Python教程:118.目录遍历2.mp4 │ ├─千锋Python教程:第13章 正则表达式(5集) │ 千锋Python教程:119.正则表达式概述&re; 模块概述&常用函数&单字符匹配语法1.mp4 │ 千锋Python教程:120.正则表达式概述&re; 模块概述&常用函数&单字符匹配语法2.mp4 │ 千锋Python教程:121.正则表达式概述&re; 模块概述&常用函数&单字符匹配语法3.mp4 │ 千锋Python教程:122.正则表达式深入方式使用1.mp4 │ 千锋Python教程:123.正则表达式深入方式使用2.mp4 │ ├─千锋Python教程:第14章 进程和线程(12集) │ 千锋Python教程:124.多任务原理&进程概述&单任务现象&实现多任务1.mp4 │ 千锋Python教程:125.多任务原理&进程概述&单任务现象&实现多任务2.mp4 │ 千锋Python教程:126.多任务原理&进程概述&单任务现象&实现多任务3.mp4 │ 千锋Python教程:127.父子进程&启动进程&进程对象封装1.mp4 │ 千锋Python教程:128.父子进程&启动进程&进程对象封装2.mp4 │ 千锋Python教程:129.进程间的通信&线程概述&启动多线程1.mp4 │ 千锋Python教程:130.进程间的通信&线程概述&启动多线程2.mp4 │ 千锋Python教程:131.线程间数据共享&线程锁1.mp4 │ 千锋Python教程:132.线程间数据共享&线程锁2.mp4 │ 千锋Python教程:133.线程间数据共享&线程锁3.mp4 │ 千锋Python教程:134.定时线程&线程通信&生产者与消费者&线程调度1.mp4 │ 千锋Python教程:135.定时线程&线程通信&生产者与消费者&线程调度2.mp4 │ ├─千锋Python教程:第15章 网络编程(6集) │ 千锋Python教程:136.网络编程概述1.mp4 │ 千锋Python教程:137.网络编程概述2.mp4 │ 千锋Python教程:138.基于TCP的网络编程1.mp4 │ 千锋Python教程:139.基于TCP的网络编程2.mp4 │ 千锋Python教程:140.基于UDP的网络编程.mp4 │ 千锋Python教程:141.全网轰炸.mp4 │ ├─千锋Python教程:第16章 协程&同步异步&并发并行&编码(11集)规范 │ 千锋Python教程:142.协程概述&数据传递&生产者与消费者1.mp4 │ 千锋Python教程:143.协程概述&数据传递&生产者与消费者2.mp4 │ 千锋Python教程:144.同步异步&asyncio;模块块&协程与任务的定义及阻塞与 await1.mp4 │ 千锋Python教程:145.同步异步&asyncio;模块块&协程与任务的定义及阻塞与 await2.mp4 │ 千锋Python教程:146.同步异步&asyncio;模块块&协程与任务的定义及阻塞与 await3.mp4 │ 千锋Python教程:147.并发并行&协程嵌套&获取网页数据1.mp4 │ 千锋Python教程:148.并发并行&协程嵌套&获取网页数据2.mp4 │ 千锋Python教程:149.并发并行&协程嵌套&获取网页数据3.mp4 │ 千锋Python教程:150.chardet 模块&py2;与py3的区别&PEP8;编码规范1.mp4 │ 千锋Python教程:151.chardet 模块&py2;与py3的区别&PEP8;编码规范2.mp4 │ 千锋Python教程:152.chardet 模块&py2;与py3的区别&PEP8;编码规范3.mp4 │ └─千锋Python教程:第17章 Linux&git;(23集) 千锋Python教程:153.Linux概述1.mp4 千锋Python教程:154.Linux概述2.mp4 千锋Python教程:155.git的使用1.mp4 千锋Python教程:156.git的使用2.mp4 千锋Python教程:157.git的使用3.mp4 千锋Python教程:158.git 的使用1.mp4 千锋Python教程:159.git 的使用2.mp4 千锋Python教程:160.安装虚拟机&Ubantu; 镜像1.mp4 千锋Python教程:161.安装虚拟机&Ubantu; 镜像2.mp4 千锋Python教程:162.安装虚拟机&Ubantu; 镜像3.mp4 千锋Python教程:163.Linux 命令1.mp4 千锋Python教程:164.Linux 命令2.mp4 千锋Python教程:165.linux 命令1.mp4 千锋Python教程:166.linux 命令2.mp4 千锋Python教程:167.linux 命令&远程连接 linux.mp4 千锋Python教程:168.vi 编辑器1.mp4 千锋Python教程:169.vi 编辑器2.mp4 千锋Python教程:170.用户管理权限&阿里云的使用1.mp4 千锋Python教程:171.用户管理权限&阿里云的使用2.mp4 千锋Python教程:172.手动安装 Python3.6的环境&虚拟机环境1.mp4 千锋Python教程:173.手动安装 Python3.6的环境&虚拟机环境2.mp4 千锋Python教程:174.git 的使用1.mp4 千锋Python教程:175.git 的使用2.mp4
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值