【问题标题】:How to get Sqlite3 column names containing a value?如何获取包含值的 Sqlite3 列名?
【发布时间】:2019-07-23 21:35:49
【问题描述】:

我有一个 sqlite3 表,其中包含 0 和 1。 我想获取值为 1 的列名。 我已经尝试了 description 和 pragma 方法,但由于某种原因结果不正确。

以下是我的尝试:

.description

allResults = c.execute("SELECT * FROM db_1.hope5 WHERE Vehicle = '{}'".format(veh))
all_columnNames = [tup[0] for tup in allResults.description]
inputs_columnNames = all_columnNames[9:]
inputcheck = [tup[9:] for tup in allResults.fetchall()]
inputSelected = [val for i, val in enumerate(inputs_columnNames) if inputcheck[0][i] == 1]

编译指示

c = connection.cursor()
        c.execute("PRAGMA TABLE_INFO(hope5)")
        names = [tup[1] for tup in c.fetchall()]
        names = names[2:]
        result = c.execute("SELECT * FROM hope5 WHERE Vehicle = '{}' ".format(veh))
        result = result.fetchall()
        test = [names[index] for index, val in enumerate(result[0][2:]) if val==1]

桌子的形状

+----+-----+-----+-----+-----+-----+
| A  |  B  |  C  |  D  |  E  |  F  |
+----+-----+-----+-----+-----+-----+
| 0  |  0  |  1  |  0  | 0   |  1  |
|----|-----|-----|-----|-----|-----|
| 1  |  0  |  0  |  0  | 1   |  0  |
+----+-----+-----+-----+-----+-----+

根据我上面的代码,结果需要是:

test = [A,C,E,F]

【问题讨论】:

标签: python sqlite


【解决方案1】:

所以问题是:

inputSelected = [val for i, val in enumerate(inputs_columnNames) if inputcheck[0][i] == 1]

inputcheck[0] 应该是 j。通过更改为以下内容:

inputSelected_append = []
for j in range(len(inputcheck)):
    inputSelected = [val for i, val in enumerate(inputs_columnNames) if inputcheck[j][i] == 1]
    inputSelected_append.append(inputSelected)

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2011-03-29
    • 2011-11-02
    • 2010-10-31
    • 1970-01-01
    • 2021-11-06
    • 1970-01-01
    • 2022-01-07
    相关资源
    最近更新 更多