Task09:else 与 with 语句(1day)

本教程将Python基础学习划分为12项任务,覆盖变量、数据类型、条件循环、函数、类对象等核心概念,配合丰富示例,如else语句在循环中的应用与异常处理技巧,以及with语句的文件操作最佳实践。

我们准备利用17天时间,将 Python 基础的刻意练习分为如下任务:

Task01:变量、运算符与数据类型(1day)
Task02:条件与循环(1day)
Task03:列表与元组(2day)
Task04:字符串与序列(1day)
Task05:函数与Lambda表达式(2day)
Task06:字典与集合(1day)
Task07:文件与文件系统(2day)
Task08:异常处理(1day)
Task09:else 与 with 语句(1day)
Task10:类与对象(2day)
Task11:魔法方法(2day)
Task12:模块(1day)

1. 丰富的 else 语句

while … else 语句

count = 0
while count < 5:
    print("%d is  less than 5" % count)
    count = count + 1
else:
    print("%d is not less than 5" % count)

# 0 is  less than 5
# 1 is  less than 5
# 2 is  less than 5
# 3 is  less than 5
# 4 is  less than 5
# 5 is not less than 5

for … else 语句
for 中的语句和普通的没有区别,else 中的语句会在循环正常执行完(即 for 不是通过 break 跳出而中断的)的情况下执行,while … else 也是一样。

for num in range(10, 20):  # 迭代 10 到 20 之间的数字
    for i in range(2, num):  # 根据因子迭代
        if num % i == 0:  # 确定第一个因子
            j = num / i  # 计算第二个因子
            print('%d 等于 %d * %d' % (num, i, j))
            break  # 跳出当前循环
    else:  # 循环的 else 部分
        print(num, '是一个质数')

# 10 等于 2 * 5
# 11 是一个质数
# 12 等于 2 * 6
# 13 是一个质数
# 14 等于 2 * 7
# 15 等于 3 * 5
# 16 等于 2 * 8
# 17 是一个质数
# 18 等于 2 * 9
# 19 是一个质数

try …. except … else 语句

如果在 try 子句执行时没有发生异常,Python将执行 else 语句后的语句(如果有 else 的话),然后控制流通过整个 try 语句。

try:
    正常的操作
   ......................
except:
    发生异常,执行这块代码
   ......................
else:
    如果没有异常执行这块代码

使用 except 而不带任何异常类型,这不是一个很好的方式,我们不能通过该程序识别出具体的异常信息,因为它捕获所有的异常

try:
    正常的操作
   ......................
except(Exception1[, Exception2[,...ExceptionN]]]):
   发生以上多个异常中的一个,执行这块代码
   ......................
else:
    如果没有异常执行这块代码

Sample:

try:
    fh = open("testfile", "w")
    fh.write("这是一个测试文件,用于测试异常!!")
except IOError:
    print("Error: 没有找到文件或读取文件失败")
else:
    print("内容写入文件成功")
    fh.close()

# 内容写入文件成功

2. 简洁的 with 语句

一些对象定义了标准的清理行为,无论系统是否成功的使用了它,一旦不需要它了,那么这个标准的清理行为就会执行。

关键词 with 语句就可以保证诸如文件之类的对象在使用完之后一定会正确的执行它的清理方法。例如finall

try:
    f = open('myfile.txt', 'w')
    for line in f:
        print(line)
except OSError as error:
    print('出错啦!%s' % str(error))
finally:
    f.close()

# 出错啦!not readable

这段代码执行完毕后,就算在处理过程中出问题了,文件 f 总是会关闭。

try:
    with open('myfile.txt', 'w') as f:
        for line in f:
            print(line)
except OSError as error:
    print('出错啦!%s' % str(error))

# 出错啦!not readable    
请编写 SQL 语句,统计每个有效任务(至少有 1 名玩家有效领取)的以下信息: 任务 ID(task_id) 有效领取人数(仅统计在任务下发后 7 天内领取的玩家数,同一玩家对同一任务多次领取仅算 1 人) 活跃度正向影响人数(有效领取玩家中,领取后 14 天总游玩时长 > 领取前 14 天总游玩时长的人数) 正向影响率(正向影响人数 / 有效领取人数) 时间计算规则: 有效领取判断:领取时间(receive_time)在任务下发时间(issue_time)至 下发时间 + 7 天(含首尾时间)范围内 领取前 14 天:领取时间(receive_time)的前 14 天(含领取当天),例如 2025-10-01 领取,则统计 2025-09-17 至 2025-09-30 的游玩时长 领取后 14 天:领取时间(receive_time)的后 14 天(含领取当天),例如 2025-10-01 领取,则统计 2025-10-01 至 2025-10-14 的游玩时长:WITH valid_receives_player_table AS ( SELECT player_id ,task_id ,task_name ,issue_aftr_7_day_date ,receive_time FROM ( SELECT t2.player_id ,t1.task_id ,t1.task_name ,from_unixtime((unix_timestamp(t1.issue_time,'yyyy-MM-dd HH:mm:ss') + (7*24*60*60)),'yyyy-MM-dd HH:mm:ss') as issue_aftr_7_day_date ,t2.receive_time FROM ods_game_dev.task_issue t1 JOIN ods_game_dev.player_task_receives t2 ON t1.task_id = t2.task_id ) t3 WHERE issue_aftr_7_day_date <=receive_time ) SELECT tmp1.task_id ,tmp1.valid_cnt ,tmp2.value_cnt1 ,ROUND(tmp2.value_cnt1/tmp1.valid_cnt,4) AS zxyx_rate FROM( SELECT task_id ,COUNT(player_id) AS valid_cnt FROM valid_receives_player_table GROUP BY task_id )tmp1 JOIN ( SELECT task_id ,COUNT(player_id) AS value_cnt1 FROM ( SELECT t1.task_id ,t1.player_id ,SUM(CASE WHEN date_sub(t1.receive_time,14) <= play_date AND play_date < date_sub(t1.receive_time,1) THEN duration_min END ) AS befor_receive_14_day_duration_sum ,SUM(CASE WHEN date_add(t1.receive_time,1) <= play_date AND play_date < date_add(t1.receive_time,14) THEN duration_min END ) AS after_receive_14_day_duration_sum FROM valid_receives_player_table t1 JOIN ods_game_dev.player_play_durations t2 ON t1.player_id = t2.player_id GROUP BY t1.task_id ,t1.player_id )t3 WHERE befor_receive_14_day_duration_sum < after_receive_14_day_duration_sum GROUP BY task_id ) tmp2 ON tmp1.task_id = tmp2.task_id 这个sql对吗
最新发布
11-25
SET @sql = NULL; SELECT JSON_ARRAYAGG( CONCAT('MAX(CASE WHEN td.person_name = ''', person_name, ''' THEN td.work_time ELSE NULL END) AS ''', person_name, '''') ) INTO @sql FROM ( SELECT DISTINCT t2.person_name FROM task1 t1 INNER JOIN t_ps_person_work_time t2 ON t1.id = t2.task_id WHERE t2.work_day BETWEEN '2025-06-26' AND '2025-07-25' AND t2.status = 0 ) t; -- 更精确地移除JSON数组格式 SET @sql = TRIM(BOTH '[""]' FROM @sql); SET @sql = REPLACE(@sql, '","', '", "'); -- 可选,如果需要处理中间部分 -- 或者更简单的方式(如果只有两个元素): SET @sql = REPLACE(REPLACE(@sql, '"', ''), ',', ', '); SET @sql = REPLACE(@sql, '[', ''); SET @sql = REPLACE(@sql, ']', ''); WITH task_data AS ( -- 获取任务和人员工时数据 SELECT t3.task_num , t3.project_name , (SELECT dict_label FROM `js_sys_dict_data` WHERE dict_type = 'sys_project_type' AND dict_value = t3.project_type) project_type, t1.duty_person person_name, ROUND(SUM(t2.work_time), 1) work_time, t2.work_day workDay FROM project t3 INNER JOIN task1 t1 ON t3.id = t1.project_id INNER JOIN ( SELECT person_name, task_id, work_time, DATE_FORMAT(work_day, '%Y-%m') work_day FROM t_ps_person_work_time WHERE work_day BETWEEN '2025-06-26' AND '2025-07-25' AND `status` = 0 ORDER BY work_day ) t2 ON t1.id = t2.task_id WHERE t3.status = 0 AND t1.status = 0 GROUP BY t3.id,t1.person_code ORDER BY t3.task_num ) -- 动态透视表查询 SET @sql = CONCAT('SELECT td.task_num AS "任务书号", td.project_name AS "项目名称", td.project_type AS "项目类型", ROUND(SUM(td.work_time), 1) AS "项目工时", ', @sql, ' FROM task_data td GROUP BY td.task_num ORDER BY td.task_num'); -- 现在,@sql中存储了动态生成的SQL字符串 -- 使用预处理语句执行 PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt; 我这样修改,> 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'SET @sql = CONCAT('SELECT td.task_num AS "任务书号", td.project_name A' at line 29出现这个错误
08-09
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值