python开发技巧---基于python3实现

1、列表推导式

你有一个list:bag = [1, 2, 3, 4, 5]

现在你想让所有元素翻倍,让它看起来是这个样子:[2, 4, 6, 8, 10]

大多初学者,根据之前语言的经验会大概这样来做

bag = [1, 2, 3, 4, 5]  
for i in range(len(bag)):  
    bag[i] = bag[i] * 2
但是有更好的方法:
bag = [elem * 2 for elem in bag]
很简洁对不对?这叫做Python的列表推导式。


2. 遍历列表

继续,还是上面的列表。

如果可能尽量避免这样做:

bag = [1, 2, 3, 4, 5]  
for i in range(len(bag)):  
     print(bag[i])
取而代之的应该是这样:

bag = [1, 2, 3, 4, 5]  
for i in bag:  
     print(i)
如果 x是一个列表,你可以对它的元素进行迭代。多数情况下你不需要各元素的索引,但如果你非要这样做,那就用 enumerate函数。它像下边的样子:

bag = [1, 2, 3, 4, 5]  
for index, element in enumerate(bag):  
     print(index, element)

3. 元素互换

如果你是从java或者C语言转到Python来,可能会习惯于这样:

    a = 5  
    b = 10
    # 交换 a 和 b
    tmp = a  
    a = b  
    b = tmp

但Python提供了一个更自然更好的方法!

    a = 5  
    b = 10  
    # 交换a 和 b
    a, b = b, a

4. 初始化列表

假如你要一个是10个整数0的列表,你可能首先想到:

    bag = []  
    for _ in range(10):  
        bag.append(0)

换个方式吧:

    bag = [0] * 10

看,多优雅。

注意:如果你列表包含了列表,这样做会产生浅拷贝。

举个例子:

    bag_of_bags = [[0]] * 5 # [[0], [0], [0], [0], [0]]  
    bag_of_bags[0][0] = 1 # [[1], [1], [1], [1], [1]]

Oops!所有的列表都改变了,而我们只是想要改变第一个列表。

改一改啦:

    bag_of_bags = [[0] for _ in range(5)]  
    # [[0], [0], [0], [0], [0]]
    bag_of_bags[0][0] = 1  
    # [[1], [0], [0], [0], [0]]

同时记住:

“过早优化是万恶之源”

问问自己,初始化一个列表是必须的吗?

5. 构造字符串

你会经常需要打印字符串。要是有很多变量,避免下面这样:

name = "Raymond"  
age = 22  
born_in = "Oakland, CA"  
string = "Hello my name is " + name + "and I'm " + str(age) + " years old. I was born in " + born_in + "."  
print(string

额,这看起来多乱呀?你可以用个漂亮简洁的方法来代替,.format

这样做:

name = "Raymond"  
age = 22  
born_in = "Oakland, CA"  
string = "Hello my name is {0} and I'm {1} years old. I was born in {2}.".format(name, age, born_in) 
print(string)

6.返回tuples

Python允许你在一个函数中返回多个元素,这让生活更简单。但是在解包元组的时候出出线这样的常见错误:

    def binary():  
        return 0, 1
    result = binary()  
    zero = result[0]  
    one = result[1]
这是没必要的,你完全可以换成这样:

    def binary():  
        return 0, 1
    zero, one = binary()
要是你需要所有的元素被返回,用个下划线 _

    zero, _ = binary()
就是这么高效率

7. 访问Dicts

你也会经常给dicts中写入key,pair(键,值)。

如果你试图访问一个不存在的于dictkey,可能会为了避免KeyError错误,你会倾向于这样做:

    countr = {}  
    bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]  
    for i in bag:  
        if i in countr:
            countr[i] += 1
        else:
            countr[i] = 1
    for i in range(10):  
        if i in countr:
            print("Count of {}: {}".format(i, countr[i]))
        else:
            print("Count of {}: {}".format(i, 0))
但是,用 get()是个更好的办法。

    countr = {}  
    bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]  
    for i in bag:  
        countr[i] = countr.get(i, 0) + 1
    for i in range(10):  
        print("Count of {}: {}".format(i, countr.get(i, 0)))

当然你也可以用setdefault来代替。

这还用一个更简单却多费点开销的办法:


    bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]  
    countr = dict([(num, bag.count(num)) for num in bag])
    for i in range(10):  
        print("Count of {}: {}".format(i, countr.get(i, 0)))
你也可以用 dict推导式。
    countr = {num: bag.count(num) for num in bag}

这两种方法开销大是因为它们在每次 count被调用时都会对列表遍历。

8. 使用库

现有的库只需导入你就可以做你真正想做的了。

还是说前面的例子,我们建一个函数来数一个数字在列表中出现的次数。那么,已经有一个库就可以做这样的事情。

    from collections import Counter  
    bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7]  
    countr = Counter(bag)
    for i in range(10):  
        print("Count of {}: {}".format(i, countr[i]))

一些用库的理由:

  • 代码是正确而且经过测试的。
  • 它们的算法可能会是最优的,这样就跑的更快。
  • 抽象化:它们指向明确而且文档友好,你可以专注于那些还没有被实现的。
  • 最后,它都已经在那儿了,你不用再造轮子了。

9. 在列表中切片/步进

你可以指定 start的点和 stop点,就像这样 list[start:stop:step]。我们取出列表中的前5个元素:

    bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]  
    for elem in bag[:5]:  
        print(elem)

这就是切片,我们指定stop点是5,再停止前就会从列表中取出5个元素。

要是最后5个元素怎么做?

    bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]  
    for elem in bag[-5:]:  
        print(elem)

没看明白吗?-5意味着从列表的结尾取出5个元素。

如果你想对列表中元素间隔操作,你可能会这样做:

    bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]  
    for index, elem in enumerate(bag):  
        if index % 2 == 0:
            print(elem)
但是你应该这样来做:

    bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]  
    for elem in bag[::2]:  
        print(elem)
    # 或者用 ranges
    bag = list(range(0,10,2))  
    print(bag)

这就是列表中的步进。list[::2]意思是遍历列表同时两步取出一个元素。

你可以用list[::-1]很酷的翻转列表。

10. tab键还是空格键

长时间来看,将tab和空格混在一起会造成灾难,你会看到IndentationError: unexpected indent。不管你选择tab键还是空格键,你应该在你的文件和项目中一直保持使用。

一个使用空格而不是tab的原因是,tab不是在所有编辑器中都一样的。视呢所用的编辑器,tab可能会被当作2到8个空格。

你也可以在写代码时用空格来定义tab。这样你可以自己选择用几个空格来当做tab。大多数Python用户是用4个空格。


















  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 是一种脚本语言,广泛应用于各类编程和数据分析任务。在机器学习和人工智能领域,Python 也是一门常用的编程语言。基于 Python 的 gym-carracing 是 OpenAI Gym 的一个环境,用于模拟汽车驾驶场景。 这个自动驾驶项目的目标是让计算机通过机器学习算法来自动驾驶模拟的汽车。首先,我们需要安装 gym-carracing 环境及其相关依赖库。然后,我们可以使用强化学习算法,比如深度强化学习算法(如深度 Q 网络),训练一个智能驾驶代理程序。 在训练过程中,代理程序会不断与环境进行交互,获取当前的观测状态,然后根据某种策略选择一个动作作为响应。之后,代理程序会根据环境给予的反馈来调整自己的策略和动作选择,以逐步提升驾驶技能。 在 gym-carracing 环境中,汽车会在一个虚拟的赛道上行驶,玩家需要使用方向键控制汽车的转向,以应对各种道路和弯道情况。在自动驾驶项目中,我们的目标是通过训练智能代理程序,使它能够自动控制汽车,适应不同的道路和驾驶情景,并以高效、安全的方式行驶。 该项目的难点在于设计和实现一个合适的驾驶策略,并通过强化学习算法不断优化代理程序的决策能力。为了取得好的效果,我们可能需要进行大量的训练和参数调整,并结合一些技巧和经验,优化代理程序的性能。 总而言之,Python 和 gym-carracing 提供了一个有趣且实用的平台,可用于开发自动驾驶项目。通过合理的算法和大量的训练,我们希望能够训练出一个高效、智能的驾驶代理程序,使其能够在模拟环境中完成自动驾驶任务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值