
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 08, 2016 07:41 PM
Is there any plan for an API to pull metadata? It’s currently very difficult to infer the schema, you have to resort to hacks like reading all records and then trying to infer types and column names from that. It’d be great if you could pull the schema information for a table more easily!
It’d also be awesome if you’d be able to add and change tables from the API, but that’s less pressing to me :slightly_smiling_face:

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jul 10, 2020 12:14 PM
Sometimes it’s hard to understand whether Airtable really is trying to be a professional solution or not.

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jul 10, 2020 03:17 PM
Are you guys aware of the many ways that have emerged to get at the schema? Here’s one. There are others like this one, and this one.

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Aug 25, 2020 06:30 AM
Yes, because clearly a hack is much better than a proper metadata API.

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Aug 26, 2020 08:46 AM
Is the way to do this now to create a custom block? Looks like its possible through that - Airtable Blocks SDK

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 19, 2020 07:24 AM
I know this is a bit of middle ages as you have to press the button RUN everytime you need to modify your tables…
But i got this as a compromise.
Create a new table where you will store your Schema.
I called it ‘Ledger’ just for clarity.
create a block and use this code, it will populate it with the names of your tables, and then you can use it to make api calls.
let ledger = base.getTable('Ledger');
let tableList = []
for (table of base.tables) {tableList.push({fields: {'Name' : table.name}})}
await ledger.createRecordsAsync(tableList)
if you want to avoid async random return order of your records you can store it in a string and then parse it as an array in your app.
let ledger = base.getTable('Ledger');
let tableList = ""
for (table of base.tables) {
if (base.tables.indexOf(table) == base.tables.length - 1) {
tableList += table.name
}
else {
tableList += table.name + ", "
}
}
await ledger.createRecordsAsync([{
fields: {'Name' : tableList }
}])

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 20, 2020 08:43 PM
Should be native, no? :frowning:

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 21, 2020 07:13 AM
I don’t understand your comment. I’m very old; give me more context.

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 23, 2020 08:18 PM
I would love to be able to create an object-oriented Python API for my Airtable base. The current inability to query the schema definition via the API is a problem.

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 23, 2020 08:42 PM
And I’m feeling old. Perhaps best to move along :grinning_face_with_big_eyes:

- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 24, 2020 09:42 AM
I tried this and it works great!. I save the json out to a file, then load it into python / dataframe for various uses. Thanks Chester.
