先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Python全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Python知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024c (备注Python)
正文
print('及格')
elif 70 <= score < 80:
print(‘良’)
elif 80 <= score < 90:
print(‘好’)
elif score >= 90:
print(‘优秀’)
else:
print(‘你要努力了’)
### 16-石头剪刀布
import random
all_choices = [‘石头’, ‘剪刀’, ‘布’]
computer = random.choice(all_choices)
player = input('请出拳: ')
print(‘Your choice:’, player, “Computer’s choice:”, computer)
print(“Your choice: %s, Computer’s choice: %s” % (player, computer))
if player == ‘石头’:
if computer == ‘石头’:
print(‘平局’)
elif computer == ‘剪刀’:
print(‘You WIN!!!’)
else:
print(‘You LOSE!!!’)
elif player == ‘剪刀’:
if computer == ‘石头’:
print(‘You LOSE!!!’)
elif computer == ‘剪刀’:
print(‘平局’)
else:
print(‘You WIN!!!’)
else:
if computer == ‘石头’:
print(‘You WIN!!!’)
elif computer == ‘剪刀’:
print(‘You LOSE!!!’)
else:
print(‘平局’)
### 17-改进的石头剪刀布
import random
all_choices = [‘石头’, ‘剪刀’, ‘布’]
win_list = [[‘石头’, ‘剪刀’], [‘剪刀’, ‘布’], [‘布’, ‘石头’]]
prompt = “”“(0) 石头
(1) 剪刀
(2) 布
请选择(0/1/2): “””
computer = random.choice(all_choices)
ind = int(input(prompt))
player = all_choices[ind]
print(“Your choice: %s, Computer’s choice: %s” % (player, computer))
if player == computer:
print(‘\033[32;1m平局\033[0m’)
elif [player, computer] in win_list:
print(‘\033[31;1mYou WIN!!!\033[0m’)
else:
print(‘\033[31;1mYou LOSE!!!\033[0m’)
### 18-猜数,直到猜对
import random
num = random.randint(1, 10)
running = True
while running:
answer = int(input('guess the number: '))
if answer > num:
print(‘猜大了’)
elif answer < num:
print(‘猜小了’)
else:
print(‘猜对了’)
running = False
### 19-猜数,5次机会
import random
num = random.randint(1, 10)
counter = 0
while counter < 5:
answer = int(input('guess the number: '))
if answer > num:
print(‘猜大了’)
elif answer < num:
print(‘猜小了’)
else:
print(‘猜对了’)
break
counter += 1
else: # 循环被break就不执行了,没有被break才执行
print(‘the number is:’, num)
### 20-while循环,累加至100
因为循环次数是已知的,实际使用时,建议用for循环
sum100 = 0
counter = 1
while counter < 101:
sum100 += counter
counter += 1
print(sum100)
### 21-while-break
break是结束循环,break之后、循环体内代码不再执行。
while True:
yn = input('Continue(y/n): ')
if yn in [‘n’, ‘N’]:
break
print(‘running…’)
### 22-while-continue
计算100以内偶数之和。
continue是跳过本次循环剩余部分,回到循环条件处。
sum100 = 0
counter = 0
while counter < 100:
counter += 1
# if counter % 2:
if counter % 2 == 1:
continue
sum100 += counter
print(sum100)
### 23-for循环遍历数据对象
astr = ‘hello’
alist = [10, 20, 30]
atuple = (‘bob’, ‘tom’, ‘alice’)
adict = {‘name’: ‘john’, ‘age’: 23}
for ch in astr:
print(ch)
for i in alist:
print(i)
for name in atuple:
print(name)
for key in adict:
print(‘%s: %s’ % (key, adict[key]))
### 24-range用法及数字累加
range(10) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
# >>> list(range(10))
# range(6, 11) # [6, 7, 8, 9, 10]
# range(1, 10, 2) # [1, 3, 5, 7, 9]
# range(10, 0, -1) # [10, 9, 8, 7, 6, 5, 4, 3, 2, 1]
sum100 = 0
for i in range(1, 101):
sum100 += i
print(sum100)
### 25-列表实现斐波那契数列
列表中先给定两个数字,后面的数字总是前两个数字之和。
fib = [0, 1]
for i in range(8):
fib.append(fib[-1] + fib[-2])
print(fib)
### 26-九九乘法表
for i in range(1, 10):
for j in range(1, i + 1):
print(‘%s*%s=%s’ % (j, i, i * j), end=’ ')
print()
i=1 ->j: [1]
i=2 ->j: [1,2]
i=3 ->j: [1,2,3]
#由用户指定相乘到多少
n = int(input('number: '))
for i in range(1, n + 1):
for j in range(1, i + 1):
print(‘%s*%s=%s’ % (j, i, i * j), end=’ ')
print()
### 27-逐步实现列表解析
10+5的结果放到列表中
[10 + 5]
# 10+5这个表达式计算10次
[10 + 5 for i in range(10)]
# 10+i的i来自于循环
[10 + i for i in range(10)]
[10 + i for i in range(1, 11)]
# 通过if过滤,满足if条件的才参与10+i的运算
[10 + i for i in range(1, 11) if i % 2 == 1]
[10 + i for i in range(1, 11) if i % 2]
# 生成IP地址列表
['192.168.1.%s' % i for i in range(1, 255)]
### 28-三局两胜的石头剪刀布
import random
all_choices = [‘石头’, ‘剪刀’, ‘布’]
win_list = [[‘石头’, ‘剪刀’], [‘剪刀’, ‘布’], [‘布’, ‘石头’]]
prompt = “”“(0) 石头
(1) 剪刀
(2) 布
请选择(0/1/2): “””
cwin = 0
pwin = 0
while cwin < 2 and pwin < 2:
computer = random.choice(all_choices)
ind = int(input(prompt))
player = all_choices[ind]
print("Your choice: %s, Computer's choice: %s" % (player, computer))
if player == computer:
print('\033[32;1m平局\033[0m')
elif [player, computer] in win_list:
pwin += 1
print('\033[31;1mYou WIN!!!\033[0m')
else:
cwin += 1
print('\033[31;1mYou LOSE!!!\033[0m')
### 29-文件对象基础操作
文件操作的三个步骤:打开、读写、关闭
# cp /etc/passwd /tmp
f = open('/tmp/passwd') # 默认以r的方式打开纯文本文件
data = f.read() # read()把所有内容读取出来
print(data)
data = f.read() # 随着读写的进行,文件指针向后移动。
# 因为第一个f.read()已经把文件指针移动到结尾了,所以再读就没有数据了
# 所以data是空字符串
f.close()
f = open('/tmp/passwd')
data = f.read(4) # 读4字节
f.readline() # 读到换行符\n结束
f.readlines() # 把每一行数据读出来放到列表中
f.close()
################################
f = open('/tmp/passwd')
for line in f:
print(line, end='')
f.close()
##############################
f = open('图片地址', 'rb') # 打开非文本文件要加参数b
f.read(4096)
f.close()
##################################
f = open('/tmp/myfile', 'w') # 'w'打开文件,如果文件不存在则创建
f.write('hello world!\n')
f.flush() # 立即将缓存中的数据同步到磁盘
f.writelines(['2nd line.\n', 'new line.\n'])
f.close() # 关闭文件的时候,数据保存到磁盘
##############################
with open('/tmp/passwd') as f:
print(f.readline())
#########################
f = open('/tmp/passwd')
f.tell() # 查看文件指针的位置
f.readline()
f.tell()
f.seek(0, 0) # 第一个数字是偏移量,第2位是数字是相对位置。
# 相对位置0表示开头,1表示当前,2表示结尾
f.tell()
f.close()
### 30-拷贝文件
拷贝文件就是以r的方式打开源文件,以w的方式打开目标文件,将源文件数据读出后,写到目标文件。
以下是【不推荐】的方式,但是可以工作:
f1 = open(‘/bin/ls’, ‘rb’)
f2 = open(‘/root/ls’, ‘wb’)
data = f1.read()
f2.write(data)
f1.close()
f2.close()
### 31-拷贝文件
每次读取4K,读完为止:
src_fname = ‘/bin/ls’
dst_fname = ‘/root/ls’
src_fobj = open(src_fname, 'rb')
dst_fobj = open(dst_fname, 'wb')
while True:
data = src_fobj.read(4096)
if not data:
break
dst_fobj.write(data)
src_fobj.close()
dst_fobj.close()
### 32-位置参数
注意:位置参数中的数字是字符形式的
import sys
print(sys.argv) # sys.argv是sys模块里的argv列表
# python3 position_args.py
# python3 position_args.py 10
# python3 position_args.py 10 bob
### 33-函数应用-斐波那契数列
def gen_fib(l):
fib = [0, 1]
for i in range(l - len(fib)):
fib.append(fib[-1] + fib[-2])
return fib # 返回列表,不返回变量fib
a = gen_fib(10)
print(a)
print(‘-’ * 50)
n = int(input("length: "))
print(gen_fib(n)) # 不会把变量n传入,是把n代表的值赋值给形参
### 34-函数-拷贝文件
import sys
def copy(src_fname, dst_fname):
src_fobj = open(src_fname, 'rb')
dst_fobj = open(dst_fname, 'wb')
while True:
data = src_fobj.read(4096)
if not data:
break
dst_fobj.write(data)
src_fobj.close()
dst_fobj.close()
copy(sys.argv[1], sys.argv[2])
# 执行方式
# cp_func.py /etc/hosts /tmp/zhuji.txt
### 35-函数-九九乘法表
def mtable(n):
for i in range(1, n + 1):
for j in range(1, i + 1):
print(‘%s*%s=%s’ % (j, i, i * j), end=’ ')
print()
mtable(6)
mtable(9)
### 36-模块基础
每一个以py作为扩展名的文件都是一个模块。
star.py:
hi = 'hello world!'
def pstar(n=50):
print('*' * n)
if __name__ == '__main__':
pstar()
pstar(30)
在call_star.py中调用star模块:
import star
print(star.hi)
star.pstar()
star.pstar(30)
### 37-生成密码/验证码
此文件名为:randpass.py
思路:
1、设置一个用于随机取出字符的基础字符串,本例使用大小写字母加数字
2、循环n次,每次随机取出一个字符
3、将各个字符拼接起来,保存到变量result中
from random import choice
import string
all_chs = string.ascii_letters + string.digits # 大小写字母加数字
def gen_pass(n=8):
result = ''
for i in range(n):
ch = choice(all_chs)
result += ch
return result
if __name__ == '__main__':
print(gen_pass())
print(gen_pass(4))
print(gen_pass(10))
### 38-序列对象方法
from random import randint
alist = list() # []
list(‘hello’) # [‘h’, ‘e’, ‘l’, ‘l’, ‘o’]
list((10, 20, 30)) # [10, 20, 30] 元组转列表
astr = str() # ‘’
str(10) # ‘10’
str([‘h’, ‘e’, ‘l’, ‘l’, ‘o’]) # 将列表转成字符串
atuple = tuple() # ()
tuple(‘hello’) # (‘h’, ‘e’, ‘l’, ‘l’, ‘o’)
num_list = [randint(1, 100) for i in range(10)]
max(num_list)
min(num_list)
### 39-序列对象方法2
alist = [10, ‘john’]
list(enumerate(alist)) # [(0, 10), (1, ‘john’)]
a, b = 0, 10 # a->0 ->10
for ind in range(len(alist)):
print(‘%s: %s’ % (ind, alist[ind]))
for item in enumerate(alist):
print(‘%s: %s’ % (item[0], item[1]))
for ind, val in enumerate(alist):
print(‘%s: %s’ % (ind, val))
atuple = (96, 97, 40, 75, 58, 34, 69, 29, 66, 90)
sorted(atuple)
sorted(‘hello’)
for i in reversed(atuple):
print(i, end=‘,’)
现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。
分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
0, 75, 58, 34, 69, 29, 66, 90)
sorted(atuple)
sorted(‘hello’)
for i in reversed(atuple):
print(i, end=‘,’)
现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。
分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注python)
[外链图片转存中…(img-rSvUGPAz-1713351116564)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!