[英]How to print a table in sqlite3 along with column names in python using a loop and how exactly to get the column names?
[英]How to get Sqlite3 column names containing a value?
我有一個sqlite3表,其中包含0和1。我想獲取值為1的列名稱。我嘗試了description和pragma方法,由於某種原因,結果不正確。
以下是我的嘗試:
。去污
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]
所以問題是:
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)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.