data:image/s3,"s3://crabby-images/751e3/751e358aea2f6649582379e0630fa9329000cebc" alt="Alba_Machado Alba_Machado"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 30, 2020 03:59 PM
Hi AirTable friends,
I have records that each have a long text field which is TOO long. That long text field is called “Excerpt.” What I’d like to do is create a formula field called “Trimmed Excerpt” that copies the content from “Excerpt” field but limits the word count to, say, 50. What’s the formula for that? I Googled for a solution but came away empty-handed. Thanks to those of you who take a crack at this one!
Solved! Go to Solution.
Accepted Solutions
data:image/s3,"s3://crabby-images/26433/26433101725e1bd577b291d9c79d4b063049f39c" alt="Jeremy_Oglesby Jeremy_Oglesby"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 30, 2020 04:45 PM
Hi @Alba_Machado,
So I think if you are wanting this to be pretty simple, you could just use the LEFT()
function. It isn’t able to parse a number of words, but it can parse a number of characters… so here’s a really simple and dumb implementation, where if we assume the average word length is 5 letters plus a space (so 6 characters total), we can extract the first 50*6 characters = 300 characters:
LEFT({Excerpt}, 300) & '...'
(Added the ellipses at the end to signify this is a snippet of a larger text)
If you are wanting something smarter than that which can parse an exact number of words, you are probably moving into Scripting app territory.
data:image/s3,"s3://crabby-images/26433/26433101725e1bd577b291d9c79d4b063049f39c" alt="Jeremy_Oglesby Jeremy_Oglesby"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 30, 2020 04:45 PM
Hi @Alba_Machado,
So I think if you are wanting this to be pretty simple, you could just use the LEFT()
function. It isn’t able to parse a number of words, but it can parse a number of characters… so here’s a really simple and dumb implementation, where if we assume the average word length is 5 letters plus a space (so 6 characters total), we can extract the first 50*6 characters = 300 characters:
LEFT({Excerpt}, 300) & '...'
(Added the ellipses at the end to signify this is a snippet of a larger text)
If you are wanting something smarter than that which can parse an exact number of words, you are probably moving into Scripting app territory.
data:image/s3,"s3://crabby-images/8ce1d/8ce1d514a2ca6f0053b60674c8ae43d9c46444b5" alt="Alba_Machado2 Alba_Machado2"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Sep 30, 2020 07:18 PM
Thanks, Jeremy! I think cutting according to characters rather than words would work for us, only it would be cool if the final word wasn’t cut off.
data:image/s3,"s3://crabby-images/26433/26433101725e1bd577b291d9c79d4b063049f39c" alt="Jeremy_Oglesby Jeremy_Oglesby"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 01, 2020 10:48 AM
Ya, I’m pretty sure if you want it to be that smart, you’ll have to move outside of formulas and into Scripting. Not sure if 1) you are on a Pro plan and have persistent access to scripting, and 2) if you actually want to dive that deep…
But if you do want to explore that, it’s definitely possible with a Script (either Scripting App or an Automation with a Scripting Action).
data:image/s3,"s3://crabby-images/940e1/940e135223332b9d19b1ab1302c3183a406470b3" alt="kuovonne kuovonne"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 01, 2020 04:54 PM
Don’t underestimate the power of a formula field!
IF(
LEN({Long text}) > 250,
LEFT(
{Long text},
FIND(" ", {Long text}, 240)
) & "...",
{Long text}
)
You can see the formula, an explanation, and a working demo on my website.
I actually use a souped up version of this formula field to create the excerpts on all the posts on my website.
data:image/s3,"s3://crabby-images/8cb2f/8cb2f3bec7aa3b8b55da0b6eb8d1d81194430375" alt=""