data:image/s3,"s3://crabby-images/01286/01286a649018134e03940cdaad71ebfcba46f4d9" alt="Kenny_Purnomo Kenny_Purnomo"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 29, 2022 10:31 PM
I have multiple images in a field. How can i change each attachment name using one click script?
The attachment name should be based on {name} field.
Thank you for the advice
data:image/s3,"s3://crabby-images/f211d/f211da1cee5485a71358daeba0228ee0c2b6d246" alt="Greg_F Greg_F"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 30, 2022 01:07 AM
Hi @Kenny_Purnomo ,
Very interesting question. I have looked into it and according to my best understanding, while you cannot use the script to rename the attachment names, you can use it to “re-upload” files with different names.
End result is the same… :winking_face:
Here is a draft script of how it could look like:
const imageTable = base.getTable("Table 1");
const recordsFromImageTable = await imageTable.selectRecordsAsync({fields:["Thumbnail","Title"]})
console.log(recordsFromImageTable)
for (let record of recordsFromImageTable.records){
console.log(record.name)
let title = record.getCellValue("Title")
let imageField = record.getCellValue("Thumbnail")
let newImageField =[]
for ( let [imageNumber,image] of imageField.entries()){
console.log(imageNumber,image,)
let findExtension = image.filename.match(/\.\w+$/) || [""]
let extension = findExtension[0]
console.log(extension)
let fileSpecificName= imageNumber>0 ? "-" + (imageNumber+1) : ""
newImageField.push( {
url:image.url,
filename: title + fileSpecificName + extension
})
}
console.log("New image field array", newImageField)
await imageTable.updateRecordAsync(record.id,
{
Thumbnail: newImageField
})
}
I was testing this on this base:
I made some assumptions here:
- Used a title field for new attachments names
- In case of multiple attachments I have added -2 -3 -4 to the name
- maintained the same extension for the files (if it was .jpg it stays as .jpg)
So the use case above is that the script renames the images to match the title of video for which I am using them.
You can also check out the YouTube video here:
I hope this helps! :v:
data:image/s3,"s3://crabby-images/0cd8c/0cd8c6602a3167f6c4f624ebf85d580a6a9c737d" alt="kennypurnomo kennypurnomo"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Oct 30, 2022 09:00 PM
Thank you for the answer!
I Copy and tweak someone’s code in other thread. Please see below link
Can i just rename it? I think someone did this
data:image/s3,"s3://crabby-images/f211d/f211da1cee5485a71358daeba0228ee0c2b6d246" alt="Greg_F Greg_F"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Nov 01, 2022 06:11 PM
Hi @kennypurnomo ,
I think the other code piece goes into similar direction. What are you missing from the solution above?
data:image/s3,"s3://crabby-images/fd698/fd698713d0baac0a63656a05635b6caad01a7886" alt=""