python基础知识点总结_str ="hello,python"suffix ="python(2)

做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。

别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。

我先来介绍一下这些东西怎么用,文末抱走。


(1)Python所有方向的学习路线(新版)

这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。

最近我才对这些路线做了一下新的更新,知识体系更全面了。

在这里插入图片描述

(2)Python学习视频

包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。

在这里插入图片描述

(3)100多个练手项目

我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。

在这里插入图片描述

(4)200多本电子书

这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。

基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。

(5)Python知识点汇总

知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。

在这里插入图片描述

(6)其他资料

还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。

在这里插入图片描述

这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • Python中,打开文件语法为
text = oepn(filePath, 操作方式,编码方式)
  • 常见操作方式
    • ‘r’:读
    • ‘w’:写
    • ‘a’:追加
  • 常见编码方式
    • utf-8
    • gbk

“r”,“w”,“a”,“rb”,“wb”,“ab”:指定对文件打开方式即文件内容操作方式,即只读,可写,追加,二进制读,二进制写,二进制追加。

13. list.insert(index, obj)方法,list.remove(obj)方法移除列表中某个值的第一个匹配项,list.extend(seq)方法在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)。

如,

lists``= [``1``,``2``,``3``]

lists.insert(``2``, [``7``,``8``,``9``])

print``(lists)

list.insert(index, obj)表示将对象插入列表的 index 位置**,在此题中 index=2(列表的索引是从0开始的),obj=[7,8,9],因此最后的结果为 [1,2,[7,8,9],3]。

*list.index(obj)*表示从列表中找出某个值第一个匹配项的索引位置。

如,

lists``= [``1``,``2``,``2``,``3``,``4``,``5``]

print``(lists.index(``2``))

返回 2 所在的第一个索引为 1。

如,

lists``= [``1``,``1``,``2``,``3``,``4``,``5``,``6``]

lists.remove(``1``)

lists.extend([``7``,``8``,``9``])

print``(lists)

返回

[1,2,3,4,5,6,7,8,9]。

  1. pass语句的作用:

pass是空语句,是为了保持程序结构的完整性,不做任何事情,一般用做占位语句。

15. dict***.fromkeys函数***:

dict.fromkeys(seq, value) 函数用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值。该方法返回一个新字典。

如,

tmp``= dict``.fromkeys([``'a'``,``'b'``],``4``)

print``(tmp)

返回{‘a’: 4, ‘b’: 4}。

  1. 装饰器函数outer

装饰器的一个关键特性是,它在被装饰函数定义后被立即执行,因此运行装饰函数outer。

如,

def outer(fn):

print(‘outer’)

def inner():

print(‘inner’)

return fn

return inner

@outer

def fun():

print(‘fun’)

返回 outer

17. 两个列表的加法表示两个列表进行拼接

a``= [``1``,``2``,``3``]

b``= [``4``,``5``,``6``]

print``(a``+``b)

结果为:[1, 2, 3, 4, 5, 6]。

列表的‘*’运算不会开辟一处内存空间,列表中的元素指向同一地址。

如,

a = [[‘1’,‘2’] for i in range(2)]

b = [[‘1’,‘2’]]*2

a[0][1] = ‘3’

b[0][0] = ‘4’

print(a,b)

使用列表生成式生成的列表a=[[‘1’, ‘2’], [‘1’, ‘2’]],列表的两个元素虽然也是列表,但它们是不同的引用,修改其中的一个列表元素不影响另一个列表元素;而使用*生成的列表b=[[‘1’, ‘2’], [‘1’, ‘2’]] ,列表的两个列表元素指向同一个地址,修改时互相影响。

  1. strip函数

strip():删除首尾空格; rstrip():仅删除右空格; lstrip():仅删除左空格。

注意:strip()返回副本;而lstrip()与rstrip()返回新的字符串,即原串被改变。

**strip方法匹配两侧所有的不符合条件的字符(括号内指定字符串中的每个字符)。

如,

strs``= 'abbacabb'

print``(strs.strip(``'ab'``))

'ab’表示的是一种集合,这里是指:[ab,ba,aa,bb,aaa,bbb,abb,baa]等;

strs两端,只要是包含了上述集合中的任何一个,都删除。

  1. copy.copy函数:

import copy

a = [1, 2, 3, 4, [‘a’, ‘b’]] 
b = a     # 引用,除非直接给a重新赋值,否则a变则b变,b变则a变

c = copy.copy(a)   #浅复制,只会拷贝父对象, 不会拷贝父对象中的子对象,所以若a的子对象变则c 变,但是父对象变c不会变
d = copy.deepcopy(a) #深拷贝,完全拷贝,完全独立于原对象,a变也不变

  1. join函数:

join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串。

如,

print``(``'\n'``.join([``'a'``,``'b'``,``'c'``]))

输出结果为

a

b

c

21. try…except…else结构解析:

try except else;

except捕获到异常时,else 语句块不会执行

try except finally;

except捕获到异常时,finally语句块会执行

22.  ***__name__***是内置属性,每一个python的对象,方法函数,类都会默认有这个字段,返回的是函数名。

自己运行自己的程序,__name__ 即为__main__

当程序当做脚本被别人调用运行时,其__name__ 为自己的模块名称。

如,

print_func.py的代码如下:

print('Hello World!')

print('__name__value: ', __name__)

def main():

print(``'This message is from main function'``)

if __name__ == '__main__':

main()

print_module.py的代码如下:

import print_func

print(``"Done!"``)

运行print_module.py程序,结果是Hello World! __name__ value: print_func Done!

23. @property

使用property会将方法转为属性。

如,

class Rect:

def __init__(self,width,height):

self.width = width

self.height = height

@property

def area(self):

return self.height* self.width

rect = Rect(10,20)

rect.area

此时的area为属性,原本的rect.area()改成了rect.area。

  1. __init__()函数:

子类若有定义__init__()函数时,将不会自动继承父类的构造函数,修改时只需在子类的__init__()函数中添加语句:super().__init__()。

如,

class Cat:

def __init__(self,color=“白色”):

self.__color = color

cat = Cat(“绿色”)

print(cat._Cat__color)

尽管color属性为私有属性,但是在类外部使用时,仍可以通过实例名._类名__xxx来访问。

25. 当内部作用域想修改外部变量时,需要使用global声明。

如,

counter``= 1

def doLotsOfStuff():

global counter

for i``in (``1``,``2``,``3``):

counter``+``= 1

doLotsOfStuff()

print counter

在局部作用域 doLotsOfStuff() 函数中,声明对全局作用域中的 counter 变量的引用,输出结果为 4。

26.  char不是python支持的数据类型。

python中没有char数据类型。

27.  不同数据类型pop函数返回值不同。

字典dict的pop是删除需要指定key的键和值,如果没有指定,则返回default,就会报错;

而list的pop是删除最后一个值并返回。

28.find() 和 index() 方法都是返回元素第一次出现的索引,区别是:find() 找不到返回-1,而index()找不到会报错。

  1. 关于re库正则表达式

re模块实现正则的功能

re.match(正则表达式,要匹配的字符串,[匹配模式])

以字符串 str1 = “Python’s features”  为例,

正则表达式 r’(.*)on(.*?) .*’

r 表示后面的字符串是一个普通字符串(比如\n会译为\和n,而不是换行符)

() 符号包住的数据为要提取的数据,通常与.group()函数连用。

. 匹配单个任意字符

* 匹配前一个字符出现0次或无限次

? 匹配前一个字符出现0次或1次

(.*) 提取的数据为str1字符串中on左边的所有字符,即Pyth

(.*?) 提取的数据为str1中on右边,空格前面,即’s

.group(0) 输出的是匹配正则表达式整体结果

.group(1) 列出第一个括号匹配部分,.group(2) 列出第二个括号匹配部分

import re

str1``= "Python's features"

str2``= re.match( r``'(.*)on(.*?) .*'``, str1, re.M|re.I)

print str2.group(``1``)

输出结果为 Pyth。

30. 关于函数返回值:

count()函数没有匹配到对象返回0

index()函数没有匹配到对象报错value Error

find()函数没有匹配到对象返回-1

in 关键字没有匹配到对象返回false

  1. @dec装饰器

def dec(fn):
    def func():
        pass
        return fn()
    return func

@dec
def foo():
    pass

@dec 装饰器,先执行dec(), 并将 @dec 下面的 函数 作为dec()的参数。 (装饰器的作用:为已经存在的对象添加额外的功能)

如,

def dec(f):

n``= 3

def wrapper(``*``args,``*``*``kw):

return f(``*``args,``*``*``kw)``* n

return wrapper

@dec

def foo(n):

return n``* 2

foo(n) = (n * 2)* 3,这里相当于传入将n*2传入到dec函数中,所以foo(2)=12,foo(3)=18。

32.isinstance() 函数来判断一个对象是否是一个已知的类型,类似 type()。

  1. issubclass() 函数用于判断参数是否是类型参数的子类。

34. str.endswith() 函数用于判断指定位置开始是否包含某字符串。

如,

str =``"Hello,Python"``;

suffix =``"Python"``;

print (str.endswith(suffix,``2``));

str.endswith(suffix,2) 中的2是指:从字符串"Hello,Python" 中的位置2,也就是第一个‘l’开始检索,判断是否以suffix结尾,故本题输出 True 。

35. enumerate() 函数用于将一个可遍历的数据对象组合为一个索引序列。

enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中,所以程序中表示返回列表的元素和对应下标乘积的累加求和。

如,

lists``= [``1``,``2``,``3``,``4``]

tmp``= 0

for i,j``in enumerate``(lists):

tmp``+``= i``* j

print``(tmp)

i   j

0 1

1 2

2 3

3 4

其中i为索引,j为数据对象list中元素,所以tmp = 0x1+1x2+2x3+3x4 = 20

36.  sort()函数与sorted()函数:

  1. sort 是应用在 list 上的方法,属于列表的成员方法,sorted 可以对所有可迭代的对象进行排序操作。
  2. list 的 sort 方法返回的是对已经存在的列表进行操作,而内建函数 sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。
  3. sort使用方法为ls.sort(),而sorted使用方法为sorted(ls)

使用sorted()进行排序会生成新的序列,生成的新序列和原序列id值必然不同。对于可变对象,sorted()进行排序时原序列也发生变化。

如,

lis = [1,3,2]

a = id(lis)

lis = sorted(lis)

b = id(lis)

print(a==b)

返回的结果是False。

对于+=操作,如果是可变对象,则操作前后序列的id值不变,如果是不可变对象,则操作前后序列的id值改变。

如,

lis = [1,3,2]

a = id(lis)

lis += [4,5]

b = id(lis)

print(a==b)

返回结果是True。

  1. replace()函数:

string.replace(str1, str2,  num=string.count(str1)),把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次。

如,

strs``= 'I like python and java'

print``(strs.replace(``'I'``,``'Your'``))

print``(strs.replace(``'a'``,``'*'``,``2``))

返回’Your like python and java’,‘I like python *nd j*va’

38. filter()函数:

Filter函数可以将迭代器的数据带入函数中,返回使函数返回值为true的值。

如,

func``= lambda x:x``%``2

result``= filter``(func, [``1``,``2``,``3``,``4``,``5``])

print``(``list``(result))

返回[1,3,5]。

39.  upper()函数用于字母大写,***title()***用于字符串首字母大写。

upper() 表示将字符小写转换为大写,title方法将字符串内每个连续字母的首字母大写,其余小写,数字后面的字母被title当成首字母大写了。

扩展:

>>> strs = 'abcd12efg'
>>> strs.upper()    # 所有字母全大写
'ABCD12EFG'
>>> strs.lower()    # 所有字母全小写
'abcd12efg'
>>> strs.upper().title()    # 单词首字母大写
'Abcd12Efg'
>>> strs.title()
'Abcd12Efg'
>>> strs.capitalize()        # 字符串首字母大写
'Abcd12efg'
>>> "12abc".capitalize()
'12abc'

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

img
img

二、Python必备开发工具

工具都帮大家整理好了,安装就可直接上手!img

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

img

四、Python视频合集

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

img

五、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。img

六、面试宝典

在这里插入图片描述

在这里插入图片描述

简历模板在这里插入图片描述

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值