做了那么多年开发,自学了很多门编程语言,我很明白学习资源对于学一门新语言的重要性,这些年也收藏了不少的Python干货,对我来说这些东西确实已经用不到了,但对于准备自学Python的人来说,或许它就是一个宝藏,可以给你省去很多的时间和精力。
别在网上瞎学了,我最近也做了一些资源的更新,只要你是我的粉丝,这期福利你都可拿走。
我先来介绍一下这些东西怎么用,文末抱走。
(1)Python所有方向的学习路线(新版)
这是我花了几天的时间去把Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
最近我才对这些路线做了一下新的更新,知识体系更全面了。
(2)Python学习视频
包含了Python入门、爬虫、数据分析和web开发的学习视频,总共100多个,虽然没有那么全面,但是对于入门来说是没问题的,学完这些之后,你可以按照我上面的学习路线去网上找其他的知识资源进行进阶。
(3)100多个练手项目
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了,只是里面的项目比较多,水平也是参差不齐,大家可以挑自己能做的项目去练练。
(4)200多本电子书
这些年我也收藏了很多电子书,大概200多本,有时候带实体书不方便的话,我就会去打开电子书看看,书籍可不一定比视频教程差,尤其是权威的技术书籍。
基本上主流的和经典的都有,这里我就不放图了,版权问题,个人看看是没有问题的。
(5)Python知识点汇总
知识点汇总有点像学习路线,但与学习路线不同的点就在于,知识点汇总更为细致,里面包含了对具体知识点的简单说明,而我们的学习路线则更为抽象和简单,只是为了方便大家只是某个领域你应该学习哪些技术栈。
(6)其他资料
还有其他的一些东西,比如说我自己出的Python入门图文类教程,没有电脑的时候用手机也可以学习知识,学会了理论之后再去敲代码实践验证,还有Python中文版的库资料、MySQL和HTML标签大全等等,这些都是可以送给粉丝们的东西。
这些都不是什么非常值钱的东西,但对于没有资源或者资源不是很好的学习者来说确实很不错,你要是用得到的话都可以直接抱走,关注过我的人都知道,这些都是可以拿到的。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
2024软件测试面试刷题,这个小程序(永久刷题),靠它快速找到工作了!(刷题APP的天花板)_软件测试刷题小程序-CSDN博客文章浏览阅读2.8k次,点赞85次,收藏12次。你知不知道有这么一个软件测试面试的刷题小程序。里面包含了面试常问的软件测试基础题,web自动化测试、app自动化测试、接口测试、性能测试、自动化测试、安全测试及一些常问到的人力资源题目。最主要的是他还收集了像阿里、华为这样的大厂面试真题,还有互动交流板块……_软件测试刷题小程序https://blog.csdn.net/AI_Green/article/details/134931243?spm=1001.2014.3001.5502深拷贝(deep copy)常用于复制请求参数、配置对象或其他复杂数据结构,以确保每次发送请求时使用的是独立的数据副本,避免不同请求之间的数据互相影响。例如,当你需要多次调用同一个接口,但每次调用的参数略有不同的时候,深拷贝可以帮助你创建参数对象的新实例。
基础示例
import requests
import copy
# 假设有一个包含接口请求参数的字典
base_params = {
'user_id': 123,
'data': {
'name': 'Alice',
'address': {
'street': '123 Main St'
}
}
}
# 在接口自动化测试中,我们可能需要对某些参数进行修改后发起请求
def send_request(modified_params):
# 使用深拷贝来创建原始参数的一个完整副本
params = copy.deepcopy(base_params)
# 现在可以安全地修改副本而不影响原始参数
params['user_id'] = modified_params['user_id']
params['data']['name'] = modified_params.get('new_name', params['data']['name'])
# 发送HTTP请求
response = requests.post('http://api.example.com/endpoint', json=params)
# 处理响应并验证结果...
# 调用函数,传入要修改的参数
test_case_1_params = {'user_id': 456, 'new_name': 'Bob'}
send_request(test_case_1_params)
# 下一个测试案例,使用不同的参数
test_case_2_params = {'user_id': 789, 'new_name': 'Charlie'}
send_request(test_case_2_params)
在这个例子中,copy.deepcopy() 方法被用来创建 base_params 的深拷贝,这样每个测试用例都可以根据需要独立修改参数,并且不会干扰其他测试用例或后续的请求。这对于维护数据一致性以及避免由于数据共享导致的问题非常有用。
深拷贝处理列表、字典嵌套的数据结构
包含多个请求参数集合的列表,每个集合代表一次独立的接口调用:
import copy
import requests
# 假设我们有一系列需要以不同参数发送的请求
base_requests = [
{
'method': 'POST',
'url': 'http://api.example.com/user',
'data': {
'user_id': 1,
'name': 'Alice'
}
},
{
'method': 'POST',
'url': 'http://api.example.com/user',
'data': {
'user_id': 2,
'name': 'Bob'
}
}
]
def send_requests(modified_requests):
# 对原始请求列表进行深拷贝
requests_to_send = copy.deepcopy(base_requests)
for request in requests_to_send:
# 根据测试需求修改每个请求的参数
request['data']['name'] = modified_requests[request['data']['user_id']]['new_name']
# 发送HTTP请求
response = requests.request(request['method'], request['url'], json=request['data'])
# 处理响应并验证结果...
# 定义要修改的用户名称
modified_user_names = {
1: 'Charlie',
2: 'Dave'
}
# 调用函数,传入要修改的参数
send_requests(modified_user_names)
在这个例子中,通过深拷贝base_requests列表,我们可以对每个请求中的数据进行独立修改,而不会影响到其他请求或后续的测试。这样就能确保在并发或批量执行接口测试时,每次请求使用的都是独立的数据副本。
深拷贝管理复杂的会话状态或全局配置
全局配置对象,包含了所有请求的通用头信息或其他默认设置:
import requests
import copy
# 全局配置对象
global_config = {
'headers': {
'Content-Type': 'application/json',
'Authorization': 'Bearer some_token'
},
'timeout': 30,
'proxies': {...}
}
# 定义一个发送请求的函数,利用深拷贝来创建全局配置的副本
def send_request(url, data, custom_config={}):
# 创建全局配置的深拷贝
config = copy.deepcopy(global_config)
# 更新或添加自定义配置
config.update(custom_config)
# 发送HTTP请求
response = requests.post(url, json=data, **config)
# 处理响应并验证结果...
# 使用默认配置发送请求
send_request('http://api.example.com/user', {'user_id': 1})
# 发送具有部分自定义配置的请求(如:更新令牌)
custom_config = {'headers': {'Authorization': 'Bearer new_token'}}
send_request('http://api.example.com/user', {'user_id': 2}, custom_config)
在这个例子中,通过深拷贝 global_config,我们可以在不改变原始全局配置的前提下,为每个单独的请求定制不同的配置项。这样在处理多用户、多环境或者需要临时修改某些配置参数的情况时,可以确保每次请求都基于独立且完整的配置对象,从而避免数据污染和错误发生。
深拷贝在持续集成(CI)或持续部署(CD)的场景使用
在并行执行多个接口测试用例时,每个测试任务可能会加载一套共享的基础数据,但需要独立操作这些数据以模拟不同的业务场景:
import threading
import copy
import requests
# 基础数据集
base_data = {
'users': [
{'id': 1, 'name': 'Alice'},
{'id': 2, 'name': 'Bob'}
],
'products': [...]
}
def run_test_case(test_case, copied_data):
# 在线程内部对复制的数据进行修改和使用
for user in copied_data['users']:
if user['id'] == test_case['user_id']:
user['name'] = test_case.get('new_name', user['name'])
# 根据测试用例发送请求
response = requests.put(f'http://api.example.com/user/{test_case["user_id"]}', json=user)
# 处理响应并验证结果...
# 定义测试用例列表
test_cases = [
{'user_id': 1, 'new_name': 'Charlie'},
{'user_id': 2, 'new_name': 'Dave'}
]
# 使用多线程并发执行测试用例,并为每个线程提供基础数据的深拷贝
threads = []
for case in test_cases:
现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。
分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习
![](https://img-blog.csdnimg.cn/img_convert/21b2604bd33c4b6713f686ddd3fe5aff.png)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618317507)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
b2604bd33c4b6713f686ddd3fe5aff.png)
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618317507)**
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**