文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python通过30秒就能学会的漂亮短程序代码(过程全解)

2024-04-02 19:55

关注

① 二维列表

 根据给定的长和宽,以及初始值,返回一个二维列表:


def initialize_2d_list(w, h, val=None):
    return [[val for x in range(w)] for y in range(h)]

例如:


>>> initialize_2d_list(2,2)
[[None, None], [None, None]]

>>> initialize_2d_list(2,2,0)
[[0, 0], [0, 0]]

② 函数切割数组

使用一个函数应用到一个数组的每个元素上,使得这个数组被切割成两个部分。如果说,函数应用到元素上返回的值为 True,则该元素被切割到第一部分,否则分为第二部分:


def bifurcate_by(lst, fn):
    return [
      [x for x in lst if fn(x)],
      [x for x in lst if not fn(x)]
    ]

例如:


>>> bifurcate_by(['beep', 'boop', 'foo', 'bar'], lambda x: x[0] == 'b') 
[['beep', 'boop', 'bar'], ['foo']]

③ 交集点

两个数组在被一个函数应用后,从第一个数组中提取出共有的元素的原元素组成一个新的数组:


def intersection_by(a, b, fn):
    _b = set(map(fn, b))
    return [item for item in a if fn(item) in _b]

例如:


>>> from math import floor
>>> intersection_by([2.1, 1.2], [2.3, 3.4],floor)
[2.1]

④ 最大值下标

返回数组中最大值的下标:


def max_element_index(arr):
    return arr.index(max(arr))

例如:


>>> max_element_index([5, 8, 9, 7, 10, 3, 0])
4

⑤ 数组对称差

找出两个数组中不同的元素,并合成为一个新的数组:


def symmetric_difference(a, b):
    _a, _b = set(a), set(b)
    return [item for item in a if item not in _b] + [item for item in b if item not in _a]

例如:


>>> symmetric_difference([1, 2, 3], [1, 2, 4])
[3, 4]

⑥ 夹数

如果 num 落在一段数字范围内,则返回 num,否则返回离这个范围最近的边界:


def clamp_number(num,a,b):
    return max(min(num, max(a,b)),min(a,b))

例如:


>> clamp_number(2,3,10)
3

>> clamp_number(7,3,10)
7

>> clamp_number(124,3,10)
10

⑦ 键值映射


def map_values(obj, fn):
    ret = {}
    for key in obj.keys():
        ret[key] = fn(obj[key])
    return ret

例如:


>>> users = {
...   'fred': { 'user': 'fred', 'age': 40 },
...   'pebbles': { 'user': 'pebbles', 'age': 1 }
... }

>>> map_values(users, lambda u : u['age'])
{'fred': 40, 'pebbles': 1}

>>> map_values(users, lambda u : u['age']+1)
{'fred': 41, 'pebbles': 2}

⑧ 大小写转换


def decapitalize(s, upper_rest=False):
    return s[:1].lower() + (s[1:].upper() if upper_rest else s[1:])

例如:


>>> decapitalize('FooBar')
'fooBar'

>>> decapitalize('FooBar', True)
'fOOBAR'

⑨ 同键求和

对列表中的各个字典里相同键值的对象求和:


def sum_by(lst, fn):
    return sum(map(fn,lst))

例如:


>>> sum_by([{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }], lambda v : v['n'])
14

⑩ 一行代码求出现次数

求出列表中某个数出现的次数和:


def count_occurrences(lst, val):
    return len([x for x in lst if x == val and type(x) == type(val)])

例如:


>>> count_occurrences([1, 1, 2, 1, 2, 3], 1)
3

⑪ 数组再分组

对一个列表根据所需要的大小进行细分:


from math import ceil
def chunk(lst, size):
	return list (
		map(lambda x:lst[x * size:x * size + size],
			list(range(0, int(ceil(len(lst) / size))))))

效果如下:


chunk([1,2,3,4,5],2)
# [[1,2],[3,4],5]

return 中,map 的第二个参数是一个列表,map 会将列表中的每一个元素用于调用第一个参数的 function 函数,返回包含每次 function 函数返回值的新列表。

⑫ 数字转数组

同样是一则关于 map 的应用,将整形数字拆分到数组中:


def digitize(n):
    return list(map(int, str(n)))

效果如下:


digitize(123)
# [1, 2, 3]

它将整形数字n转化为字符串后,还自动对该字符串进行了序列化分割,最后将元素应用到 map 的第一个参数中,转化为整形后返回。

⑬ 非递归斐波那契


def fibonacci(n):
	if n <= 0:
		return [0]
	sequence = [0, 1]
	while len(sequence) <= n:
		next_value = (sequence[len(sequence) - 1] + sequence[len(sequence) - 2])
		sequence.append(next_value)
	return sequence

效果如下:


fibonacci(7)
# [0, 1, 1, 2, 3, 5, 8, 13]

⑭ 下划线化字符串 批量统一变量名称或者字符串格式:


from re import sub

def snake(s):
	return '_'.join(
		sub('([A-Z][a-z]+)', r' 1',
		sub('( [A-Z]+)', r' l1',
		s.replace('-', ' '))).split()).lower()

效果如下:


snake('camelCase')# 'camel_case'

snake('some text')# 'some_text'

snake('some-mixed_string With spaces_underscores-and-hyphens')# 'some_mixed_string_with_spaces_underscores_and_hyphens'

snake('AllThe-small Things')# "all_the_small_things"

到此这篇关于Python之30秒就能学会的漂亮短程序代码的文章就介绍到这了,更多相关Python短程序代码内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯