[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int

简介: 本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。

python编程_容易出现的问题_函数名的重新赋值_print_int

回忆上次内容

  • 上次 了解了
  • 关键字列表
  • keywords list

  • 关键字 不能做 标识符
  • 除了 关键字(keywords)之外
  • 还有啥 不适合 做标识符 吗?🤔

三问

  • 试试这个

print

print

print = 1

print

  • print 本是 内建的函数
  • 重新赋值后
  • 成为1了

  • 还能输出吗?

尝试输出

print("hello")

  • 不能输出了
  • 整形数字 不能被调用

  • 为啥会这样呢?

错位

  • 相当于
  • 把整形数字
  • 当成 函数来调用了

1("hello")

  • 把1 直接当做函数来 调用
  • 那哪儿成啊?

  • 除了 函数名
  • 还有啥 最好别当 变量名 吗?

常见错误

  • int 是 整数类
  • 可以完成 类型转化

b = int("6")

c = int(7.1)

  • int类型
  • 能用来转化变量类型

  • int 可以 被声明成 变量吗?

重新赋值后

int = 5

a = int(6)

  • 将 5 赋给 变量 int

  • int 一旦被 重新 赋值
  • 能 完成类型转化 了
  • 和 print 一样

观察

  • 重启 游乐场
  • 观察 类型 变化

  • 这个赋值过程
  • 从 类型(type)
  • 到 整型(int)
  • 模块名 呢?
  • 也能 这么乱赋值吗?👹

赋值

import os

os

locals()

  • 引入os
  • 本地就有了

覆盖

os = 1

os

locals()

  • 覆盖之后
  • os就不再是
  • 导入的 那个模块了

  • 那 删了 之后
  • 还能 恢复 吗?

max

  • max 也是
  • 内建的函数
  • builtin-function
  • 和 print一样

  • 将 1 赋给 max 之后
  • 再调用 max

max = 1

max(1, 2)

  • TypeError
  • max 不再是 内建的函数
  • 而是整数 无法调用了

  • 这max 能 在本地 看到 吗?

locals

locals()

  • max 此时
  • 是一个 整形变量名
  • 不是 函数名

  • 那我 要是
  • 把 max 这个变量
  • 删了呢?

删除max

del max

  • 在本地
  • 删除 max 变量

  • 本地变量 max 消失
  • __builtins__.max 从新被识别为
  • 还是 内建函数
  • builtins-function
  • 就恢复了!😄
  • 去总结吧!

总结

  • 这次 了解到
  • 已有的函数名、类名、模块名
  • 不适合 覆盖了 赋新值
  • 会 失去原有功能
  • 比如 max

  • 如果我
  • 让 max 当 变量名 表示 最大
  • 想让 max函数 可以继续被调用
  • 又该 怎么 做呢?🤔
相关文章
|
3天前
|
弹性计算 人工智能 安全
对话 | ECS如何构筑企业上云的第一道安全防线
随着中小企业加速上云,数据泄露、网络攻击等安全威胁日益严重。阿里云推出深度访谈栏目,汇聚产品技术专家,探讨云上安全问题及应对策略。首期节目聚焦ECS安全性,提出三道防线:数据安全、网络安全和身份认证与权限管理,确保用户在云端的数据主权和业务稳定。此外,阿里云还推出了“ECS 99套餐”,以高性价比提供全面的安全保障,帮助中小企业安全上云。
对话 | ECS如何构筑企业上云的第一道安全防线
|
11天前
|
调度 云计算 芯片
云超算技术跃进,阿里云牵头制定我国首个云超算国家标准
近日,由阿里云联合中国电子技术标准化研究院主导制定的首个云超算国家标准已完成报批,不久后将正式批准发布。标准规定了云超算服务涉及的云计算基础资源、资源管理、运行和调度等方面的技术要求,为云超算服务产品的设计、实现、应用和选型提供指导,为云超算在HPC应用和用户的大范围采用奠定了基础。
179614 22
|
20天前
|
人工智能 自然语言处理 前端开发
从0开始打造一款APP:前端+搭建本机服务,定制暖冬卫衣先到先得
通义灵码携手科技博主@玺哥超carry 打造全网第一个完整的、面向普通人的自然语言编程教程。完全使用 AI,再配合简单易懂的方法,只要你会打字,就能真正做出一个完整的应用。
9592 28
|
6天前
|
机器学习/深度学习 分布式计算 供应链
阿里云先知安全沙龙(上海站) ——大模型基础设施安全攻防
大模型基础设施的安全攻防体系涵盖恶意输入防御和基础设施安全,包括框架、三方库、插件、平台、模型和系统安全。关键漏洞如CVE-2023-6019(Ray框架命令注入)、CVE-2024-5480(PyTorch分布式RPC)及llama.cpp中的多个漏洞,强调了代码安全性的重要性。模型文件安全方面,需防范pickle反序列化等风险,建议使用Safetensors格式。相关实践包括构建供应链漏洞库、智能化漏洞分析和深度检测,确保全方位防护。
|
4天前
|
存储 缓存 运维
阿里云先知安全沙龙(上海站)——后渗透阶段主机关键信息自动化狩猎的实现与应用
本文介绍了在后渗透测试中使用LSTAR工具和PowerShell脚本进行RDP状态查询、端口获取及凭据收集的过程,强调了高强度实战场景下的OPSEC需求。通过MITRE ATT&CK框架的应用,详细阐述了凭证访问、发现和收集等关键技术,确保攻击者能够隐蔽、持续且高效地渗透目标系统,最终获取核心数据或控制权。文中还展示了SharpHunter等工具的自动化实现,进一步提升了操作的安全性和效率。
|
4天前
|
机器学习/深度学习 人工智能 安全
通义视觉推理大模型QVQ-72B-preview重磅上线
Qwen团队推出了新成员QVQ-72B-preview,这是一个专注于提升视觉推理能力的实验性研究模型。提升了视觉表示的效率和准确性。它在多模态评测集如MMMU、MathVista和MathVision上表现出色,尤其在数学推理任务中取得了显著进步。尽管如此,该模型仍存在一些局限性,仍在学习和完善中。
|
24天前
|
Cloud Native Apache 流计算
资料合集|Flink Forward Asia 2024 上海站
Apache Flink 年度技术盛会聚焦“回顾过去,展望未来”,涵盖流式湖仓、流批一体、Data+AI 等八大核心议题,近百家厂商参与,深入探讨前沿技术发展。小松鼠为大家整理了 FFA 2024 演讲 PPT ,可在线阅读和下载。
5185 15
资料合集|Flink Forward Asia 2024 上海站
|
1月前
|
人工智能 自动驾驶 大数据
预告 | 阿里云邀您参加2024中国生成式AI大会上海站,马上报名
大会以“智能跃进 创造无限”为主题,设置主会场峰会、分会场研讨会及展览区,聚焦大模型、AI Infra等热点议题。阿里云智算集群产品解决方案负责人丛培岩将出席并发表《高性能智算集群设计思考与实践》主题演讲。观众报名现已开放。
|
16天前
|
Docker 容器
|
5天前
|
监控 NoSQL Java
若依RuoYi项目环境搭建教程(RuoYi-Vue + RuoYi-Vue3版本)
若依(RuoYi)是一款基于Spring Boot和Vue.js的开源Java快速开发脚手架,支持OAuth2、JWT鉴权,集成多种安全框架和持久化框架。它提供了系统管理、监控管理、任务调度、代码生成等常用功能模块,适合中小型公司快速搭建Web应用。本文主要介绍若依框架的特点、版本发展、优缺点及项目部署步骤,帮助开发者快速上手并部署若依项目。
若依RuoYi项目环境搭建教程(RuoYi-Vue + RuoYi-Vue3版本)