今天要学习的技术点,Python 筛选数字,模块导入,特殊变量__all__ 实战博客 y4

举报
梦想橡皮擦 发表于 2022/04/18 16:01:26 2022/04/18
【摘要】 📢📢📢📢📢📢哈喽!大家好,我是 【梦想橡皮擦】,10 年产研经验,致力于 Python 相关技术栈传播 💗阅读前,可以去看看《滚雪球系列专栏》,系统从零开始学习 Python。每天学一点,所以本系列专栏,每篇不超过 3000 字(含代码) ⛳️ 查找计数低于 2 的数字问题场景系统初始化一个纯数字的列表,例如命名为 my_list,在该列表中找到出现数量低于 2 的所有数字。解...

📢📢📢📢📢📢
哈喽!大家好,我是 【梦想橡皮擦】,10 年产研经验,致力于 Python 相关技术栈传播 💗

阅读前,可以去看看《滚雪球系列专栏》,系统从零开始学习 Python。

每天学一点,所以本系列专栏,每篇不超过 3000 字(含代码)

⛳️ 查找计数低于 2 的数字

问题场景
系统初始化一个纯数字的列表,例如命名为 my_list,在该列表中找到出现数量低于 2 的所有数字。

解决思路
先模拟一些数据:
例如:
操作 my_list = [1,2,3,3,4,4,5,5,6] 之后,返回 1,2,6
操作 my_list = [1,2,3,3] 之后,返回 1,2

实现该案例,可以将列表从小到大进行排序,然后遍历列表,判断当前元素和下一元素大小,如果出现重复将该值存入新的数组中。

最终通过比较两个列表的差异,获取最终的数据。

编码如下

def find_over_two(nums):
    nums = sorted(nums)
    temp = []
    output = []
    for i in range(len(nums) - 1):
        if nums[i] == nums[i + 1]:
            temp.append(nums[i])
            i += 1

    for i in nums:
        if i not in temp:
            output.append(i)
    return output


if __name__ == '__main__':
    my_list = [1, 2, 3, 3, 4, 4, 5, 5, 6]

    out = find_over_two(my_list)
    print(out)

⛳️ Python 模块导入

问题场景
在 Python 代码的编写过程中,经常碰到需要使用第三方模块,或者使用团队其它人编写的模块,此时就应用到模块导入相关概念了。

解决思路
模块导入的标准语法结构为:

import 模块名称 as 别名

其中 as + 别名 在模块名称比较简单的时候,可以直接省略。别名原理类似下述代码:

import wo_shi_mo_kuai
ws = wo_shi_mo_kuai

上述代码较于 as 的缺点是,会在名称空间中产生两个变量,多一点点的的空间消耗。

import 语句不要求必须出现在文件的开头,任意位置都可以进行导入操作。

编码如下
新建一个 tools.py 文件,编写如下代码:

def show():
    print("我是橡皮擦")

在当前目录新建立一个 user.py 文件,然后导入刚才创建好的文件。

import tools
tools.show()

⛳️ 使用 from … import … 导入模块

问题场景
import 导入模块的方式会把全部内容进行导入,如果仅需要指定部分,可以使用 from...import... 导入模块中的指定成员。

解决思路和编码时间
例如下述代码:

from tools import show

除此之外,在 from 后面可以使用相对路径,例如下述代码:

from .DIR import 成员名

相对路径的逻辑与文件目录访问基本一致,可以使用 . 表示当前目录,.. 表示父级目录。

在 import 关键字之后还可以使用 *,表示导入全部成员,默认不包括下滑线 _ 开头的成员,当然也可以在模块中使用 __all__ 变量, import 默认导入该声明中的变量。

  • 如果模块定义了 __all__,默认导入该变量中的所有成员;
  • 如果无 __all__,导入非 _ 开头的变量。

⛳️ __all__ 变量

问题场景
很多时候,我们并不希望模块成员被全部导入,最好只导入我们需要的部分。这样就用到了 __all__ 变量。
解决思路和编码时间
__all__ 变量是一个序列,其中的每一个元素都是字符串,因为它可以是列表,元组类型,并且其中的元素要出现在当前名称空间中(也可以是其它模块导入的)

接下来我们在 tools.py 文件中声明三个函数:

def show1():
    print("我是橡皮擦")

def show2():
    print("我是梦想橡皮擦")

def show3():
    print("我是大佬")

__all__ = ['show1', 'show2']

在另一个文件 use.py 中,使用 from tools import *,会发现只有 show1show2 函数被导入。

from tools import *

show1()
show2()
show3()

⛳️ 在数组中找到目标数字接近值

问题场景
系统输入一个数组,然后给出一个目标数字,接下来计算数组中的任意两个数字之和,得到一个最接近目标数字的值。

解决思路
先编写 Demo,提供一个目标数字 20,提供一个数组 [1,3,4,5,6,10,21],得到最接近的数字是 16。

  1. 将数字按照从小到大进行排序,大于等于目标数字的所有值,都被舍去。
  2. 依次迭代所有剩余数字,计算每 2 个数字之和,将所有结果存储到一个新的数组中
  3. 去除新数组中大于目标数字的所有数字
  4. 获取新数组中的最大数字。

编码时间
将上述梳理出的逻辑,重现到代码中,得到如下所示结果。

arr = [1, 3, 4, 5, 6, 10, 21]
target = 20
arr = sorted(arr)
last_arr = [i for i in arr if i < target]
print("获取最终的数组如下")
print(last_arr)


# 计算所有数字之和
def get_score(new_arr):
    if len(new_arr) < 2:
        return []

    temp = []
    start = new_arr[0]

    for num in new_arr[1:]:
        item = start + num
        temp.append(item)
    return temp


all_totla = []
for index, item in enumerate(last_arr):
    all_totla += get_score(last_arr[index:])

# 重新排序
all_totla = sorted(all_totla)

# 获取最大值
last_o_arr = [i for i in all_totla if i < target]

print(last_o_arr[-1])

📣📣📣📣📣📣
🌻 本文如果发现错误,欢迎在评论区中指正哦 💗

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。