Short version:
- Get the unique ID of the Image in GDrive by ‘Get Link’, making it publicly available, and copying the text between ..file/d/ and /view
data:image/s3,"s3://crabby-images/5e496/5e4968e0a53eaf72bca8ad21fde1e65912a1e961" alt=""
data:image/s3,"s3://crabby-images/5152d/5152dddd424b0d5ea96274ace7495fd878820f65" alt=""
2. Use the ID to generate a ‘download’ url e.g.
https://drive.google.com/uc?export=download&id=YOUR-FILES-ID
3. Add a Calculated field inside of DataStudio with the Image Function
data:image/s3,"s3://crabby-images/d7eba/d7eba20db5dad2b89c50b965f4baced7781dea6c" alt=""
Image('https://drive.google.com/uc?export=download&id=YOUR-FILES-ID')
4. Use it in a Table Component
data:image/s3,"s3://crabby-images/1c962/1c96282917de18cfd201b280ba073caaa902acaa" alt=""
Long Version
Getting all the Images from one GDrive folder, and programmatically using them in a DataStudio table.
For this example we’ll use Country Flags, and show them in a table with Google Analytics Visits data to show visits by country.
- Download all the images of flags for each country for free from https://flagpedia.net/download/icons – i went with the 40px ones
2. Create a folder in your GDrive called ‘public’, make it publicaly available, and upload all the files from the downloaded zip into it.
3. Get the unique id for the Gdrive folder
data:image/s3,"s3://crabby-images/17cc3/17cc3f4a6d9c34260f127cd91d598848d40ecabd" alt=""
4. Create a new Spreadsheet listing all the filenames and their unique Gdrive id by using an App Script
- Create a new Google Sheet document from the Google account for which you want a Google Drive directory listing.
- In the toolbar for the new Google Sheet, go to Tools -> Script editor
- Replace any sample code in the editor with the code below adding your Folder Id from point 3
function listFolderContents() {
var folderid = 'YOUR-FOLDER-ID'
var folderlisting = 'contents of folder ' + folderid;
var folder = DriveApp.getFolderById(folderid)
var contents = folder.getFiles();
var ss = SpreadsheetApp.create(folderlisting);
var sheet = ss.getActiveSheet();
sheet.appendRow( ['name', 'link'] );
var file;
var name;
var link;
var row;
while(contents.hasNext()) {
file = contents.next();
name = file.getName();
link = file.getUrl();
downloadLink = link.replace(/https:\/\/drive\.google\.com\/file\/d\/(.*?)\/.*?\?usp=drivesdk/g, "https://drive.google.com/uc?export=download&id=$1");
sheet.appendRow( [name, downloadLink] );
}
};
- Save and then Run by using the buttons on the bar
- ‘Authorization required ‘ pop up will appear; grant authorization.
- A listing of the files in the specified folder, along with URLs for those files, will then appear in your My Drive as a Google Sheet named listing of folder {your-folder-id}
5. Add the GSheet as a DataSource in DataStudio
data:image/s3,"s3://crabby-images/198d7/198d7dfda5cf64dc999cca3655a7eb848c5b441d" alt=""
6. convert the filename ‘name’ into a ISO Country code by adding a new field
data:image/s3,"s3://crabby-images/3cb8c/3cb8cbc42b03895da507ddd114c25553189d5a90" alt=""
SUBSTR(UPPER(name),0,2)
7. Create another field to convert the ‘link’ to the flag image to an Image
data:image/s3,"s3://crabby-images/cf3ce/cf3ce1b800195fa15e7ad24ca2d735dc20e6ad68" alt=""
8. Add a Google Analytics Account as a 2nd DataSource
data:image/s3,"s3://crabby-images/0d10e/0d10e75480427641e222e7d24b347414311d086d" alt=""
9. Create a Blended Data Source joined on Country code
data:image/s3,"s3://crabby-images/083dd/083dd2554c08fa070ffee40c3131b9cc061e83a3" alt=""
10. Show in a Table
data:image/s3,"s3://crabby-images/8e9ec/8e9ecc08b99dcde503455d701b22932cfd822b53" alt=""
Success!
Imagine instead of Flags you used the Logos for each of your Clients.