0

我有以下二维列表

data = [['2013-02-03', 'London', 'miles', '25'], ['2013-02-03', 'Newcastle', 'miles', '25'], ['2013-02-03', 'Birmingham', 'miles', '62']]

我需要能够删除列中的任何内容,''例如下面的最后一列,以便我可以将 2D 列表传递给文本文件中的 javascript 函数。

data = [['2013-02-03', 'London', 'miles', 25], ['2013-02-03', 'Newcastle', 'miles', 25], ['2013-02-03', 'Birmingham', 'miles', 62]]

我有一个函数,可以得到单个值的结果

r = "['2013-02-03', 'London', 'miles', '25']"


def rreplace(s, old, new, occurrence):
    li = s.rsplit(old, occurrence)
    return new.join(li)

    rreplace(p, "'", '', 2)

"['2013-02-03', 'Feltham', 'less_than_one_day', 25],"

谁能提出一个更好的方法来实现这个结果?

我尝试了多种使用方法:for 循环、map/lambda 和 iter,我可以遍历列表或更改单个列表中的元素,但不能同时执行并输出结果。

4

1 回答 1

3

只需将值列表作为 Python 处理:

for row in data:
    row[-1] = int(row[-1])

这会将data嵌套列表中的每个最后一个元素替换为其等效整数。

接下来,使用json模块将其转换为有效的 JavaScript:

import json

r = json.dumps(data)

JSON 毕竟是 JavaScript 的一个子集。

快速演示:

>>> data = [['2013-02-03', 'London', 'miles', '25'], ['2013-02-03', 'Newcastle', 'miles', '25'], ['2013-02-03', 'Birmingham', 'miles', '62']]
>>> for row in data:
...     row[-1] = int(row[-1])
... 
>>> data
[['2013-02-03', 'London', 'miles', 25], ['2013-02-03', 'Newcastle', 'miles', 25], ['2013-02-03', 'Birmingham', 'miles', 62]]
>>> import json
>>> json.dumps(data)
'[["2013-02-03", "London", "miles", 25], ["2013-02-03", "Newcastle", "miles", 25], ["2013-02-03", "Birmingham", "miles", 62]]'
于 2013-05-03T13:52:32.417 回答