小编Gra*_*ell的帖子

Python中的自定义JSON sort_keys顺序

在Python 2.6中有没有办法为JSON的sort_keys提供自定义键或cmp函数?

我有一个来自JSON的dicts列表,如下所示:

[
  {
    "key": "numberpuzzles1",
    "url": "number-puzzle-i.html",
    "title": "Number Puzzle I",
    "category": "nestedloops",
    "points": "60",
    "n": "087"
  },
  {
     "key": "gettingindividualdigits",
     "url": "getting-individual-digits.html",
     "title": "Getting Individual Digits",
     "category": "nestedloops",
     "points": "80",
     "n": "088"
  }
]
Run Code Online (Sandbox Code Playgroud)

...我已经存储到list变量中了assigndb.我希望能够加载JSON,修改它,并使用dumps(或其他)将其序列化,保持密钥顺序完好无损.

到目前为止,我尝试过这样的事情:

ordering = {'key': 0, 'url': 1, 'title': 2, 'category': 3,
             'flags': 4, 'points': 5, 'n': 6}

def key_func(k):
    return ordering[k]

# renumber assignments sequentially
for (i, a) in enumerate(assigndb):
    a["n"] = "%03d" % …
Run Code Online (Sandbox Code Playgroud)

python sorting json

16
推荐指数
2
解决办法
1万
查看次数

行和列的ndarray字段名称?

我是一名计算机科学老师,正在尝试使用NumPy为自己创建一本小写本.但我认为如果我可以创建一个使用行和列的字段名称的ndarray,它将使我的代码更容易编写.这是我到目前为止所得到的:

import numpy as np
num_stud = 23
num_assign = 2
grades = np.zeros(num_stud, dtype=[('assign 1','i2'), ('assign 2','i2')]) #etc
gv = grades.view(dtype='i2').reshape(num_stud,num_assign)
Run Code Online (Sandbox Code Playgroud)

所以,如果我的第一个学生在'assign 1'上得到97,我可以写下:

grades[0]['assign 1'] = 97
gv[0][0] = 97
Run Code Online (Sandbox Code Playgroud)

另外,我可以做以下事情:

np.mean( grades['assign 1'] ) # class average for assignment 1
np.sum( gv[0] ) # total points for student 1
Run Code Online (Sandbox Code Playgroud)

这一切都有效.但我无法弄清楚该怎么做是使用学生ID号来指代某个学生(假设我的两个学生有学生ID,如图所示):

grades['123456']['assign 2'] = 95
grades['314159']['assign 2'] = 83
Run Code Online (Sandbox Code Playgroud)

...或者可能使用不同的字段名称创建第二个视图?

np.sum( gview2['314159'] ) # total points for the student with the given id
Run Code Online (Sandbox Code Playgroud)

我知道我可以创建一个dict将学生ID映射到索引,但这似乎是脆弱和苛刻的,我希望有一个更好的方法:

id2i = { …
Run Code Online (Sandbox Code Playgroud)

python numpy

7
推荐指数
3
解决办法
3179
查看次数

标签 统计

python ×2

json ×1

numpy ×1

sorting ×1