ParisGabriel 发表于 2018-7-15 21:10

【Python】人工智能全栈工程师(0基础到精通)教程 第十六课








ParisGabriel感谢 大家的支持                                全部课程 原文地址 :                                                                           http://www.cnblogs.com/ParisGabriel/tag/Python/
 https://images2018.cnblogs.com/blog/1430617/201807/1430617-20180709225751471-608583048.png                                                       https://attach.52pojie.cn/forum/201807/10/010120qq61dzx7sozu9s9s.png

                    每天坚持手写一天一篇 点个订阅吧决定坚持几年 全栈工程师(包含:python、爬虫、Web、人工智能、h5等)       讲完接着 java、黑客攻防 、渗透、                                                               易语言(比较简单学完python基本就会了)、等等到时候再说....IT无止境!   灰常感谢    当个死粉也阔以https://static.52pojie.cn/static/image/smiley/default/mad.gifhttps://static.52pojie.cn/static/image/smiley/default/mad.gif                      
                                                                              Python人工智能从入门到精通

week summer:


  字符串 str # 不可变序列,只能存字符
  列表 list # 可变的序列,可以存任意数据
  元组 tuple # 不可变序列,可以存任意数据
  字典dict # 可变无序,可以存任意数据
  集合set #可变无序,只能存不可变数据
  (可变就是id不变的情况下改变数据)序列相关函数:  len(x), max(x), min(x), sum(x), any(x), all(x)
序列有5种:
  star 字符串
  list 列表
  tuple 元组
  bytes
  bytearray列表 list:
  L = [ ]
  L = list() 创建函数 括号内放可迭代对象、可以空
  L [ ] 括号内放下标
  L [:: ] 第一个参数开始位置,第二个结束、第三个步长(步长决定方向)
  列表推导式: [表达式 for 变量 in 可迭代对象](可以嵌套)
  del L[ ] 删除指定下表索引
  列表可以索引下标 、切片 可以增、删、改、查
  可以索引赋值、切片赋值(不是顺序切片时赋值一定要个数相等)
潜拷贝
  浅拷贝是指在复制过程中,只复制一层变量,不会复制深层变量绑定的对象的复制过程https://images2018.cnblogs.com/blog/1430617/201807/1430617-20180714212003232-603478175.png
深拷贝
  深拷贝通常只对可变对象进行复制,不可变对象通常不会复制https://images2018.cnblogs.com/blog/1430617/201807/1430617-20180714212019316-1972750816.png
元组 type  t = (1, ) 低于连个元素必须用, 号
  t = type(x) 同列表一样
  元组可以索引和切片和列表一样 但是但是不能赋值
  T.index(v[, begin[, end]]) 返回对应元素的索引下标
  T.count(x) 返回元组中对应的元素个数
字典 dict:
  d = { }
  d = {“a”:1} 键值对形式存在
  d[ ] 括号里放键 ,字典索引只索引键(key)
索引赋值 : 只能修改值 ,存在修改 否者添加
  dict() 生成一个字的字典 等同于 {}
  dict(iterable) 用可迭代对象初始化一个字典
  dict(**kwargs) 用关键字传参形式创建一个字典
  字典的键(key) 必须为不可变类型 且不能重复
不可变类型:bool, int, float, complex, str, tuple, frozenset, bytes(后面再讲)
  in 在什么什么里面 not in 不在什么什么里面(判断键存在:只判断键)
  is 是 is not 不是
  所有可迭代对象都可以用for 遍历 (字典只访问键)
字典推导式 : d = {x : x ** 2 for x in range(10)}
  {键表达式 : 值表达式 for 变量 in 可迭代对象 if 真值表达式}(可嵌套)字典 VS 列表
  1. 都是可变对象
  2. 索引方式不同,列表用整数索引,字典用键索引
  3. 字典的插入,删除,修改数据的速度可能会快于列表(重要)
  4. 列表的存储是有序的,字典的存储是无序的
可变的数据类型有四种:
  list 列表、dict 字典
  set 集合、bytearray 字节数组
集合 set:
  s = set( )
  s = set( ) 构造函数
  数据不可重复 相当于只有键的字典
  集合运算:
    & 生成两个集合的交集
    | 生成两个集合的并集
    - 生成两个集合的补集
    ^ 生成两个集合的对称补集
    > 判断一个集合是另一个集合的超集
    < 判断一个集合是另一个集合的子集 (包含关系)
    == != 集合相同/不同 (与顺序无关)
集合推导式:{表达式 for 变量 in 可迭代对象 }(可嵌套)
固定集合 frozenset:
  固定集合是不可变的,无序的, 含有唯一元素的集合
    (可以做字典键也可以做集合的值)
  frozenset()
  f = frozenset() 括号内放可迭代对象
    相当于集合的全部方法(包括运算符)去掉修改集合的方法
常用字符串方法
方法                 说明
S.isdigit()                 判断字符串中的字符是否全为数字
S.isalpha()                 判断字符串是否全为英文字母
S.islower()               判断字符串所有字符是否全为小写英文字母
S.isupper()              判断字符串所有字符是否全为大写英文字母
S.isspace()              判断字符串是否全为空白字符
S.center(width[,fill])          将原字符串居中,左右默认填充空格 width:所居中字符串的长度 fill:默认填充空格
S.count(sub[, start[,end]])        获取一个字符串中子串的个数 sub:所要获取的字符串 start:起始位置 end:结束位置
S.find(sub[, start[,end]])    获取字符串中子串sub的索引,失败返回-1 start:起始位置 end:结束位置
S.strip()                  返回去掉左右空白字符的字符串
S.lstrip()                            返回去掉左侧空白字符的字符串
S.rstrip()                 返回去掉右侧空白字符的字符串
S.upper()      生成将英文转换为大写的字符串
S.lower()                  生成将英文转换为小写的字符串
S.replace(old, new[, count])          将原字符串的old用new代替,生成一个新的字符串 count:更换的次数
S.startswith(prefix[, start[, end]])   返回S是否是以prefix开头,如果以prefix开头返回True,否则返回False,
S.endswith(suffix[, start[, end]])   返回S是否是以suffix结尾,如果以suffix结尾返回True,否则返回False
以下是不常用的       
S.title()            生成每个英文单词的首字母大写字符串
S.isnumeric()   判断字符串是否全为数字字符
文本解析:
S.split(sep=None)   拆分字符串 sep是拆分符号
S.join(iterable)          S是分隔字符串 扩号内跟可迭代对象列表的方法 :
L.index(v [, begin[, end]])      返回对应元素的索引下标, begin为开始索引,end为结束索引,当 value 不存在时触发ValueError错误
L.insert(index, obj)               将某个元素插放到列表中指定的位置
L.count(x)                               返回列表中元素的个数
L.remove(x)                           从列表中删除第一次出现在列表中的值
L.copy()                                 复制此列表(只复制一层,不会复制深层对象)
L.append(x)                           向列表中追加单个元素
L.extend(lst)                           向列表追加另一个列表
L.clear()                                 清空列表,等同于 L[:] = []
L.sort(reverse=False)     将列表中的元素进行排序,默认顺序按值的小到大的顺序排列
L.reverse()         列表的反转,用来改变原列表的先后顺序
L.pop()                     删除索引对应的元素,如果不加索引,默认删除最后元素,同时返回删除元素的引用关系 字典的方法D代表字典对象       
D.clear()               清空字典
D.pop(key)         移除键,同时返回此键所对应的值
D.copy()               返回字典D的副本,只复制一层(浅拷贝)
D.update(D2)       将字典 D2 合并到D中,如果键相同,则此键的值取D2的值作为新值
D.get(key, default)        返回键key所对应的值,如果没有此键,则返回default
D.keys()            返回可迭代的 dict_keys 集合对象
D.values()              返回可迭代的 dict_values 值对象
D.items()            返回可迭代的 dict_items 对象
Python3 集合的方法:
方法        意义
S.add(e)              在集合中添加一个新的元素e;如果元素已经存在,则不添加
S.remove(e)            从集合中删除一个元素,如果元素不存在于集合中,则会产生一个KeyError错误
S.discard(e)             从集合S中移除一个元素e,在元素e不存在时什么都不做;
S.clear()              清空集合内的所有元素
S.copy()              将集合进行一次浅拷贝
S.pop()              从集合S中删除一个随机元素;如果此集合为空,则引发KeyError异常
S.update(s2)                用 S与s2得到的全集更新变量S
S.difference(s2)           用S - s2 运算,返回存在于在S中,但不在s2中的所有元素的集合
S.difference_update(s2)    等同于 S = S - s2
S.intersection(s2)            等同于 S & s2
S.intersection_update(s2)        等同于S = S & s2
S.isdisjoint(s2)            如果S与s2交集为空返回True,非空则返回False
S.issubset(s2)            如果S与s2交集为非空返回True,空则返回False
S.issuperset(...)             如果S为s2的子集返回True,否则返回False
S.symmetric_difference(s2)    返回对称补集,等同于 S ^ s2
S.symmetric_difference_update(s2)   用 S 与 s2 的对称补集更新 S
S.union(s2)             生成 S 与 s2的全集
Python运算符优先级
       运算符                    描述
(), [], {key: value}, {}                 元组表达式、列表表达式、字典表达式、集合表达式
x, x,
x(arguments...), x.attribute            索引,切片,函数调用,属性引用
**        指数    (最高优先级)
~, +, -            按位翻转, 正号,负号
*, /, %, //           乘,除,取模和地板除
+, -                加法, 减法
>>, <<                右移, 左移运算符
&        位与(AND)
^        位异或(XOR)
|        位或(OR)
<=, <, >, >=, ==, !=,
is, is not, in, not in    比较,身份测试,成员资格测试
not        布尔非
and        布尔与
or        布尔或
if - else        条件表达式
lambda        lambda表达式 数据类型:
  数值类型:
    int, float, complex, bool
容器:
  不可变的容器
    str, tuple, frozenset, bytes(字节串)
  可变的容器
    list, dict, set, bytearray(字节数组)
值:
  None, False, True运算符
  算术运算符
    + - * / // % **
  比较运算符:
    < <= > >= == !=
    in / not in
    is, is not
  布尔运算:
    not, and, or
    +(正号) -(负号)
    & | ^
    [] (索引,切片,键索引)
表达式:
  1
  1 + 2
  max(1,2,3) # 函数调用是表达式
  x if x > y else y, 条件表达式
三种推导式:
  列表,字典,集合推导式(三种)语句:
  表达式语句:
    所有的表达式都可以单独写在一行,形成一个语句,例:
    print("hello world")
    1 + 2
  赋值语句:
    a = 100
    a = b = c = 100
    x, y = 100, 200
    a = 100
    dict['name'] = 'tarena'
  del 语句
  if 语句
  while 语句
  for 语句
  break 语句
  continue语句
  pass 语句
内建函数:  len(x), max(x), min(x), sum(x), any(x), all(x)
构造函数(用来创建同类型的数据对象)
  bool(x), int(x), float(x), complex(x),
  list(x), tuple(x), str(x), dict(x), set(x),
  frozenset(x)
  abs(x)
  round(x)
  pow(x, y, z=None)  bin(x), oct(x), hex(x)
  chr(x), ord(x)
  range(start, stop, step)
  input(x), print(x)>>> help(__builtins__)函数:
  就是把语句块封装起来 形成一个语句块 利用函数变量直接调用语句块的方式
  用户自定义级别的函数是为了提高代码的可用性 重用性 以及逻辑清晰 维护方便
  (def 函数名(形参列表):冒号)  形参列表可以为空 函数是一个空间,空间内变量不重复就不会冲突函数调用:
  函数名(实参)
  return语句 用于返回非None对象语句函数的参数传递:
  传参方式:(2种)
    位置传参(包含关系 )
      序列传参
    关键字传参(包含关系)
      字典关键字传参
位置传参:
  实参与形参的位置要对应
序列传参:
  用 * 将序列拆解 然后位置传参
关键字传参  将字典用“**”拆解后 实参和形参必须按形参名复制
  拆解后键名要在形参中存在必须一致
  键名必须是字符串且标识符
综合传参:
  在能确定形参能唯一匹配到相应实参的情况下 所有传参方式可以任意组合
  位置传参(序列传参)一定要在关键字传参(字典关键字传参)的左侧
函数的缺省参数:
  缺省参数必须从右至左依次存在的
命名关键字形参:
  语法:
    def 函数名(*, 命名关键字形参):
      语句块
    或
    ef 函数名(*args, 命名关键字形参):
      语句块
    (关键字形参 必须用关键字传参)  作用:
    收集多余关键字传参
双星号字典传参:
  语法:
    def 函数名(**字典形参名):
      语句块
  作用:
    强制所有的参数都参数都必须用关键字传参或字典关键字传参
函数的参数说明:
  位置形参、星号元组形参、命名关键字形参、双星号字典形参可以混合使用
函数自左到右的顺序为:
  1.位置形参
  2.星号元组形参
  3.命名关键字形参
  4.双星号字典形参全局变量:global variable:
  函数外,模块内的变量
  全局变量所有函数都可以直接访问
局部变量:local variable:
  函数内的变量
  调用时才被创建,在函数调用之后销毁
传参的排序规则:
  从左到右 1.位置形参 2.星号元组形参 3.命名关键字形参 4.双星号字典形参函数:  globals()/locals()
  globals()返回当前全局作用域内变量的字典
  locals() 返回当前局部作用域内变量的字典

  函数名是变量 创建时绑定函数
  函数的变量名可以序列交换算法
  函数可以作为另一个函数的实参
  函数可以作为另一个函数返回值
  函数可以嵌套
python的4个作用域:
  作用域:                英文解释             缩写
  局部作用域(函数内)           Local(function)            L
  外部嵌套函数作用域          Enclosing functio loc     E
  函数定义所在模块(文件)作用域      Global(module)      G
  python内建模块作用域         Builtin(python)     B
      包含关系(内建>模块>外部嵌套函数>函数内)
变量名查找规则:
  访问变量时,先查找本地变量,然后是包裹此函数外的函数内部的变量
  ,之后是全局变量,最后是内建变量
  L ---> E ---> G ---> B
  在默认情况下,变量名赋值会创建或者改变当前作用域的变量
global语句:
  声明一个全局变量
nonlocal语句:
  外部嵌套函数变量
  调用不可修改外部嵌套函数作用域内的变量进行操作
lambda表达式: 创建一个匿名函数对象
  lambda[ 参数1, 参数...]: 表达式函数:
  eval () / exec() 函数
  eval(srouce,globals=None, locals=None)
  把一个字符串srouce
  当成一个表达式来执行,返回表达式结果
  eval(source, globals=None, local=None) 把一个字符串 srouce 当成一个表达式来执行,返回表达式执行的结果
  exec(source, globals=None, locals=None) 把一个字符串source 当成程序来执行全部划重点 加粗 加长 加大https://images2018.cnblogs.com/blog/1430617/201807/1430617-20180714214940838-61923442.png   https://images2018.cnblogs.com/blog/1430617/201807/1430617-20180714214959518-1812342351.jpg   溜了不吹NB了....

mh888666 发表于 2018-7-15 22:01

我怎么都看不懂呢

a124839 发表于 2018-7-15 22:13

python基础,人工智能的概念太大。。

CJTRAND 发表于 2018-7-15 22:29

很详细,非常感谢~{:1_929:}

yifeng 发表于 2018-7-16 08:39

一课一课的,很蛋疼{:1_925:}

小黑LLB 发表于 2019-2-3 16:39

整理的好详细 给赞{:1_921:}
页: [1]
查看完整版本: 【Python】人工智能全栈工程师(0基础到精通)教程 第十六课