- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我需要一些帮助来理解为什么这段代码没有按预期工作。
如果想改变字典的键值但保留值,他/她可能会使用:
d[new_key] = d.pop[old_key]
我想修改所有键(并保留值)但下面的代码跳过了某些行 - ("col2") 保持不变。是不是因为字典是无序的,我一直在改变它的值?
如何在不创建新字典的情况下更改键并保留值?
import time
import pprint
name_dict = {"col1": 973, "col2": "1452 29th Street",
"col3": "Here is a value", "col4" : "Here is another value",
"col5" : "NULL", "col6": "Scottsdale",
"col7": "N/A", "col8" : "41.5946922",
"col9": "Building", "col10" : "Commercial"}
for k, v in name_dict.items():
print("This is the key: '%s' and this is the value '%s'\n" % (k, v) )
new_key = input("Please enter a new key: ")
name_dict[new_key] = name_dict.pop(k)
time.sleep(4)
pprint.pprint(name_dict)
最佳答案
更改您正在迭代的对象绝不是一个好主意。通常 dict
甚至会在您尝试时抛出异常:
name_dict = {1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6}
for k, v in name_dict.items():
name_dict.pop(k)
RuntimeError: dictionary changed size during iteration
但是在您的情况下,您为每个删除的项目添加一个项目。这使它更加复杂。要了解正在发生的事情,您需要知道字典有点像稀疏表。例如,像 {1: 1, 3: 3, 5: 5}
这样的字典可能看起来像这样(这在 Python 3.6 中发生了变化,对于 3.6 和更新版本,以下内容不再正确):
hash key value
- - -
1 1 1
- - -
3 3 3
- - -
5 5 5
- - -
- - -
- - -
这也是迭代的顺序。因此,在第一次迭代中,它将转到第二项(存储 1:1
的位置)。假设您将键更改为 2
并删除键 1
字典将如下所示:
hash key value
- - -
- - -
2 2 1
3 3 3
- - -
5 5 5
- - -
- - -
- - -
但我们仍在第二行,因此下一次迭代将转到下一个“非空”条目,即 2: 1
。哎呀……
使用字符串作为键会更加复杂,因为字符串哈希是随机的(基于每个 session ),因此字典中的顺序是不可预测的。
在 3.6 中,内部布局发生了一些变化,但这里发生了类似的事情。
假设你有这个循环:
name_dict = {1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6}
for k, v in name_dict.items():
# print(k, k+6, name_dict.__sizeof__())
name_dict[k+6] = name_dict.pop(k)
# print(name_dict)
初始布局是这样的:
key value
1 1
2 2
3 3
4 4
5 5
6 1
第一个循环删除 1
但添加 7
。因为字典在 3.6 中是有序的,所以这会在 1
所在的位置插入一个占位符:
key value
- -
2 2
3 3
4 4
5 5
6 1
7 2
这种情况一直持续到您将 4
替换为 10
为止。
key value
- -
- -
- -
- -
5 5
6 1
7 2
8 3
9 4
10 5
但是当您将 5
替换为 11
时,字典将需要增加它的大小。然后发生了一些特别的事情:占位符被删除了:
key value
6 6
7 1
8 2
9 3
10 4
11 5
因此,我们在上一次迭代中位于位置 5,现在我们更改第 6 行。但是第 6 行现在包含 11: 5
。哎呀……
您可以改为保留一个“翻译表”(不知道这是否违反了您的“不创建新字典”的要求,但您需要某种存储才能使您的代码正常工作)并在循环后进行重命名:
translate = {}
for k, v in name_dict.items():
print("This is the key: '%s' and this is the value '%s'\n" % (k, v) )
new_key = input("Please enter a new key: ")
translate[k] = new_key
time.sleep(4)
for old, new in translate.items():
name_dict[new] = name_dict.pop(old)
关于python - 如何使用 d.items() 更改 for 循环中的所有字典键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45877614/
这里我试图在 FlatList 中显示一个名为“posts”的数组。 render() { console.log(this.props.posts); return (
这是我的代码: {{day(list)}} {{list.weather[0].description}}
我是 Mahout 的新手,并且仍在使用它。 我的问题是,将 Item-Item 和 User-Item 结合起来是否合适? 我的用例是,一个社交网络应用会尝试根据用户历史数据(优先级较高)为当前用户
下午好, 我按数据库搜索以测试特定类测试,当我放置一个新项目时,如果列表包含该项目。 @Test public void insertAndDeleteTask() throws Interrupte
我有一个关于 ionic 框架的问题,我希望有人能帮助我...我有一个带有“ion-item-right”的 ionic 列表。这一切都可以,按钮在右边。现在我需要其他三个居中的图标,这样我就有了:文
我经常遇到类似下面的代码: if ( items != null) { foreach(T item in items) { //... } } 基本上,if 条件确
我最近问了a question about LocalStorage .使用 JSON.parse(localStorage.item) 和 JSON.parse(localStorage['item
我最近问了a question about LocalStorage .使用 JSON.parse(localStorage.item) 和 JSON.parse(localStorage['item
这个问题已经有答案了: Type mismatch: cannot convert from Item to Item (1 个回答) 已关闭 7 年前。 我很困惑。我无法将外部类的实例变量 Node
我目前正在使用 MUI Grid(但我对替代解决方案持开放态度)并且我想要并排放置两个组件:最右边的组件占 400px宽度和左侧组件占据其余部分。 || || || 当页面宽度缩小时: | | ||
我最近问过a question about LocalStorage 。使用 JSON.parse(localStorage.item) 和 JSON.parse(localStorage['item
public class Document extends Model { ... @ManyToMany public Set accessors; ... } 我想选择访问者包含某个用户的所有文档
我正在使用 selenium webdriver 为单页 Web 应用程序开发一个 Java 框架,使用以下模式:PageObject、SlowLoadableComponent(责任链)、PageF
最近在学习C,在网上发现了一个问题。问题是: What is the problem with this function in terms of memory allocation? What is
我有这个代码 ( -1 ? true : false} /> {genre.item.name}
在ASP.Net中使用DataGrid时真的没有快捷方法吗 (e.Item.ItemType==ListItemType.Item || e.Item.ItemType==ListItemType.A
我正在使用工作流程根据数据和一组要求将大量 pdf 从一个位置复制到其他大坝位置。我正在使用以下代码 Assets damAsset = manager.createAsset(path, is, m
我是 PowerShell 的新手。 我正在尝试自动将 dll 组件从源服务器上的文件夹部署到目标服务器上的多个文件夹。这看起来应该很简单:将组件从源服务器上的源(部署)文件夹复制到目标服务器上的文件
我的代码: for column_name, column_data in summary_words.iteritems(): if column_name != "summary" and
我的代码: for column_name, column_data in summary_words.iteritems(): if column_name != "summary" and
我是一名优秀的程序员,十分优秀!