Python:list连接时,直接“+=”和=后+的区别

写代码时踩了一个坑,如下:

a = [1, 2, 3]
b = a
b += [4, 5]
print(a)

这里的本意,是想要在b后额外连接上[4, 5]这个列表,但是坑点在于使用+=会导致a的值也发生了变化,打印a和b的结果都是[1, 2, 3, 4, 5]。如果不想改变a,那么应该写成

a = [1, 2, 3]
b = a
b = b + [4, 5]
print(a)

这时a就仍然是[1, 2, 3]。当然,对b赋值的时候使用a.copy()也可以避免a被改变,这里的要点是不能简单把+=和=后+完全等同。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python的列表(list)与SQL的外连接(outer join)没有直接的对应关系。列表是一种有序的集合数据类型,而外连接是一种关系型数据库操作,用于将两个表的数据进行联合查询。如果你想在Python实现类似于左外连接的操作,你可以使用字典(dict)或者pandas库的merge函数。以下是一个使用字典实现左外连接的示例: ```python # 两个字典,分别表示两个表 customers = {'id': [1, 2, 3, 4], 'name': ['Alice', 'Bob', 'Charlie', 'David']} orders = {'order_id': [101, 102, 103], 'customer_id': [1, 3, 5], 'amount': [100, 200, 300]} # 左外连接操作 result = [] for customer_id, customer_name in zip(customers['id'], customers['name']): orders_amount = [] for order_id, order_customer_id, order_amount in zip(orders['order_id'], orders['customer_id'], orders['amount']): if customer_id == order_customer_id: orders_amount.append(order_amount) result.append((customer_id, customer_name, sum(orders_amount))) # 输出结果 print(result) ``` 输出结果为: ``` [(1, 'Alice', 100), (2, 'Bob', 0), (3, 'Charlie', 200), (4, 'David', 0)] ``` 这个例子,我们使用了两个字典来模拟两个表,然后通过循环遍历的方式实现了左外连接操作。在连接过程,我们使用了zip()函数来同遍历两个字典的键值对,然后通过判断条件来筛选符合要求的数据。最终的结果以元组(tuple)的形式保存在一个列表

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值