0

我正在使用 django 1.8、Python 2.7.5、django-datatables-view 1.2datatables 1.10.6。尝试使用columndefscolumns.render时出现以下错误:

警告:请求未知...

我在这里查阅了有关此的文档,基本上发现数据表不知道我要的是什么数据,因为它找不到它。所以我查看了数据是如何返回的:

{
    "recordsTotal": 176,
    "recordsFiltered": 176,
    "draw": 0,
    "data": [
        [
            109,
            "Hostname1",
            "1.1.1.1",
            "Excluded",
            "Down"
        ],
        [
            116,
            "Hostname2",
            "2.2.2.2",
            "Excluded",
            "Up"
        ],
        ...
    ],
    "result": "ok"
}

所以我在使用 PHP 之前使用过数据表,为了使用列 def,你需要一个 key:value 对,这样你就可以定义"data": "Key"哪个显然不是。我想我已经缩小了构建准备结果的范围:

def prepare_results(self, qs):
    data = []
    for item in qs:
        data.append([self.render_column(item, column) for column in self.get_columns()])
    return data

我一生都无法弄清楚如何将此列表列表转换为以下列方式返回结果的字典:

{
    "recordsTotal": 176,
    "recordsFiltered": 176,
    "draw": 0,
    "data": [
        {
            "Rest Id": "109",
            "Host Name": "Hostname1",
            "Ip Address": "1.1.1.1",
            "Mode": "Excluded",
            "State": "Down"
        },
        {
            "Rest Id": "116",
            "Host Name": "Hostname2",
            "Ip Address": "2.2.2.2",
            "Mode": "Excluded",
            "State": "Up"
        },
        ...
    ],
    "result": "ok"
}

我知道我可以通过 dict 理解来完成我想要做的事情,但我无法找到一种方法来完全按照我希望返回输出的方式来获得它。我还必须相信,有一种更好的方法可以做到这一点,而不是在已经准备好列表之后对列表进行 dict 理解。任何和所有的帮助将不胜感激。先感谢您。

4

2 回答 2

2

假设您的数据进入datas变量,您可以执行以下操作:

keys = ["Rest Id", "Host Name", "Ip Address", "Mode", "State"]
datas["data"] = [dict(zip(keys, d)) for d in datas["data"]]
于 2015-04-10T08:11:57.250 回答
0

我很抱歉,但我通过数据表 javascript 直接解决了我自己的问题,而不是在 python 代码中进行更改:

"columnDefs": [
    {
        "targets": 0,
        "data": 0,
        "render": function ( data, type, full, meta ) {
            return '<span data-clipboard-text="' + data + '">' + String(data) + '</span>' + 
            '<a href="URLICANNOTSHARE' + data + 
            'MOREOFTHEURLICANNOTSHARE" class="btn btn-info btn-xs" role="button" target="_blank" style="float:right;"><span class="glyphicon glyphicon-search" aria-hidden="true"></span></a>';
            },
    },
    ....
],

我也脑补了我上面所说的,我应该说的是默认情况下数据表需要一个 javascript 对象(至少他们拥有的每个示例都显示正在解析的数据是一个对象)但我返回的是一个 javascript数组(如果你有半个大脑,仍然有效,我没有)。将保持开放状态,看看是否可以提供 python 解决方案。

于 2015-04-13T06:18:35.517 回答