有没有办法在sqlite中获取列名列表?

2023-09-20数据库问题
10

本文介绍了有没有办法在sqlite中获取列名列表?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我想从数据库的表中获取列名列表.使用 pragma 我得到一个包含大量不需要信息的元组列表.有没有办法只获取列名?所以我可能会得到这样的结果:

I want to get a list of column names from a table in a database. Using pragma I get a list of tuples with a lot of unneeded information. Is there a way to get only the column names? So I might end up with something like this:

[第 1 列、第 2 列、第 3 列、第 4 列]

[Column1, Column2, Column3, Column4]

我绝对需要这个列表的原因是因为我想在列表中搜索一个列名并获取索引,因为我的很多代码中都使用了索引.

The reason why I absolutely need this list is because I want to search for a column name in the list and get the index because the index is used in a lot of my code.

有没有办法得到这样的列表?

Is there a way of getting a list like this?

谢谢

推荐答案

你可以使用 sqlite3 和 pep-249

You can use sqlite3 and pep-249

import sqlite3
connection = sqlite3.connect('~/foo.sqlite')
cursor = connection.execute('select * from bar')

cursor.description 是列的描述

names = list(map(lambda x: x[0], cursor.description))

或者,您可以使用列表推导式:

Alternatively you could use a list comprehension:

names = [description[0] for description in cursor.description]

这篇关于有没有办法在sqlite中获取列名列表?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

SQL 子句“GROUP BY 1"是什么意思?意思是?
What does SQL clause quot;GROUP BY 1quot; mean?(SQL 子句“GROUP BY 1是什么意思?意思是?)...
2024-04-16 数据库问题
62

如何在MySQL中为每个组选择第一行?
How to select the first row for each group in MySQL?(如何在MySQL中为每个组选择第一行?)...
2024-04-16 数据库问题
13

MySQL - 获取最低值
MySQL - Fetching lowest value(MySQL - 获取最低值)...
2024-04-16 数据库问题
8

在 cmakelist.txt 中添加和链接 mysql 库
Add and link mysql libraries in a cmakelist.txt(在 cmakelist.txt 中添加和链接 mysql 库)...
2024-04-16 数据库问题
41

定义外键有什么好处
what are the advantages of defining a foreign key(定义外键有什么好处)...
2024-04-16 数据库问题
7

音乐库 MySQL 数据库
Music library MySQL database(音乐库 MySQL 数据库)...
2024-04-16 数据库问题
6