我正在尋找一種解決方案來替換必須保留名稱的檔案的內容資料
因為,我希望放置在 HTML 中的影像的 URL 保持固定且永不更改。但是,在這個 url 中,影像發生了變化。
例如,默認廣告圖片永久顯示。1 月 1 日時,我們將“新年快樂”圖片更改 3 周,然后在第 4 周之后,我們恢復默認的廣告圖片。
這是我下面的程式的一部分,用于替換影像內容。使用“setcontent”,它不起作用......如何替換檔案“test_pub.png”中的內容,
function chercherimage()
{
Logger.log('Debut chercherimage() ');
//** aller chercher l'image publicitaire
var FilePub_id ="1cqGT3TV5M_RMqXj6MSD8LEjNaip2Iyio";
var folder_name ="pub";
// Get folder by id
var folderIter = DriveApp.getFoldersByName(folder_name);
var Dossier = folderIter.next();
var Id_Dossier = Dossier.getId()
Logger.log('Dossier :' Dossier.getName() );
var filesIter = Dossier.getFiles();
var i = 0;
var flag ="N";
while(filesIter.hasNext())
{
i ;
var file = filesIter.next();
var file_id = file.getId();
var filename = file .getName();
if (filename =="INE_marche_national_toulouse.png")
{
if ( FilePub_id == file_id )
{
var flag ="O";
Logger.log('file_id trouvé :' file_id );
var filesize = file .getSize();
var data = Utilities.base64Encode(file.getBlob().getBytes());
var Mime_Type=file.getMimeType();
Logger.log('filename :' filename);
Logger.log('filesize :' filesize );
Logger.log('data :' data );
Logger.log('Mime_Type :' Mime_Type );
var parm_info =[folder_name,Id_Dossier, file_id, filename, filesize , file , data, Mime_Type ];
// lancer pour remplacer le contenu de l'image dans le drive pub partage
remplace_file(parm_info);
break;
}
}
}
Logger.log('Fin chercherimage() ');
}
function remplace_file(parm_info)
{
// ces variables trouvées
var folder_name_source = parm_info[0];
var Id_Dossier_source = parm_info[1];
var file_id_source = parm_info[2];
var filename_source = parm_info[3];
var filesize_source = parm_info[4];
var file_source =parm_info[5];
var data_source =parm_info[6];
var Mime_Type_source = parm_info[7];
// preparation pour remplacer le contenu de ces variables dans le lien partagé
// aller chercher le dossier partagé : image_partagé
var folder_name ="pubpartage";
var folderIter = DriveApp.getFoldersByName(folder_name);
var Dossier_partage = folderIter.next();
var Id_Dossier = Dossier_partage .getId()
Logger.log('Dossier_partage :' Dossier_partage .getName() );
var filesIter =Dossier_partage.getFiles();
var i=0;
while(filesIter.hasNext())
{
i ;
var file = filesIter.next();
var file_name = file.getName();
var file_id = file.getId();
Logger.log('file_id partage :' file_id );
Logger.log('file_name partage :' file_name );
// à remplacer les contenus des données ...
if (file_name =="test_pub.png")
{
// ==> error how to do to correct it, see below :
// file.setcontent(data_source );
break;
}
}
}
uj5u.com熱心網友回復:
經過我的測驗,由于出現錯誤訊息,它不起作用:找不到檔案ID!!!...我不明白為什么會出現此錯誤,但我檢查了錯誤點以在回圈讀取期間捕獲 n°file !!!. 我應該如何定位確切的檔案號?
當然,我把“var data = file.getBlob();” 在另一個函式“chercherimage()”中。
請參閱下面的函式“remplace_file(parm_info)”
function remplace_file(parm_info)
{
// ces variables trouvées
var folder_name_source = parm_info[0];
var Id_Dossier_source = parm_info[1];
var file_id_source = parm_info[2];
var filename_source = parm_info[3];
var filesize_source = parm_info[4];
var file_source =parm_info[5];
var data_source =parm_info[6];
var Mime_Type_source = parm_info[7];
// preparation pour remplacer le contenu de ces variables dans le lien partagé
// aller chercher le dossier partagé : image_partagé
var folder_name ="pubpartage";
var folderIter = DriveApp.getFoldersByName(folder_name);
var Dossier_partage = folderIter.next();
var Id_Dossier = Dossier_partage .getId()
Logger.log('Dossier_partage :' Dossier_partage .getName() );
var filesIter =Dossier_partage.getFiles();
var i=0;
while(filesIter.hasNext())
{
i ;
var file = filesIter.next();
var file_name = file.getName();
var file_id = file.getId();
var mimeType = file.getMimeType();
Logger.log('file_id partage :' file_id );
Logger.log('file_name partage :' file_name );
Logger.log('mimeType partage :' mimeType );
// à remplacer les contenus des données ...
if (file_name =="test_pub.png")
{
var file_resource = {
title: file_name,
mimeType: mimeType
};
Drive.Files.update(file_resource, file_id, data_source);
break;
}
}
}

uj5u.com熱心網友回復:
我嘗試了關于函式“Drive.Files.update”的檔案目錄的 JSON,見下文。
這是行不通的 。關于 reoertory,我對名為“file_test”的 JSON 語法做得不好?
如何找到要修改內容的檔案目錄?
function remplace_file(parm_info)
{
// ces variables trouvées
var folder_name_source = parm_info[0];
var Id_Dossier_source = parm_info[1];
var file_id_source = parm_info[2];
var filename_source = parm_info[3];
var filesize_source = parm_info[4];
var file_source =parm_info[5];
var data_source =parm_info[6];
var Mime_Type_source = parm_info[7];
// preparation pour remplacer le contenu de ces variables dans le lien partagé
// aller chercher le dossier partagé : image_partagé
var folder_name ="pubpartage";
var folderIter = DriveApp.getFoldersByName(folder_name);
var Dossier_partage = folderIter.next();
var Id_Dossier = Dossier_partage .getId()
Logger.log('Dossier_partage :' Dossier_partage .getName() );
var filesIter =Dossier_partage.getFiles();
var i=0;
while(filesIter.hasNext())
{
i ;
var file = filesIter.next();
var file_name = file.getName();
var file_id = file.getId();
var mimeType = file.getMimeType();
Logger.log('file_id partage :' file_id );
Logger.log('file_name partage :' file_name );
Logger.log('mimeType partage :' mimeType );
// à remplacer les contenus des données ...
if (file_name =="test_pub.png")
{
// var file_resource = {
// title: file_name,
// mimeType: mimeType
// };
var file_test = {
title: file_name,
"parents": [{'id':Id_Dossier }],
mimeType: mimeType
};
Drive.Files.update(file_test,file_id , data_source);
break;
}
}
}
uj5u.com熱心網友回復:
問題:
- 經測驗,錯誤為
TypeError: file.setcontent is not a function。它應該是file.setContent

解決方案:
- 我建議您使用 Drive API 服務來更新檔案。首先啟用它,然后進行以下修改:
修改一:
- 已
data包含 blob,因為Drive.files.update稍后將需要 blob 型別的資料。
var data = file.getBlob();
修改二:
- 采用
Drive.files.update
if (file_name == "test_pub.png") {
var file_resource = {
title: file_name,
mimeType: Mime_Type_source
};
Drive.Files.update(file_resource, file_id, data_source);
break;
}
酒館:

出版:

編輯:
- 如果要更新共享驅動器中的檔案,請嘗試以下附加修改:
修改3:
- 改為使用其 ID 指定檔案夾。
DriveApp.getFoldersByName只會搜索您自己的驅動器。
// shared folder ID
var Id_Dossier = '0AGwRX5g4Y1d8Uk9PVA';
var Dossier_partage = DriveApp.getFolderById(Id_Dossier);
修改4:
- 在您的資源中添加其他資料,并且
supportsAllDrives:true必須添加到Drive.Files.update.
var file_resource = {
title: file_name,
mimeType: Mime_Type_source,
driveId: Id_Dossier,
parents: Id_Dossier
};
Drive.Files.update(file_resource, file_id, data_source, {supportsAllDrives:true});
Script:
function chercherimage() {
Logger.log('Debut chercherimage() ');
//** aller chercher l'image publicitaire
var FilePub_id = "<original file id>";
var folder_name = "pub";
// Get folder by id
var folderIter = DriveApp.getFoldersByName(folder_name);
var Dossier = folderIter.next();
var Id_Dossier = Dossier.getId()
Logger.log('Dossier :' Dossier.getName());
var filesIter = Dossier.getFiles();
var i = 0;
var flag = "N";
while (filesIter.hasNext()) {
i ;
var file = filesIter.next();
var file_id = file.getId();
var filename = file.getName();
if (filename == "INE_marche_national_toulouse.png") {
if (FilePub_id == file_id) {
var flag = "O";
Logger.log('file_id trouvé :' file_id);
var filesize = file.getSize();
var data = file.getBlob();
var Mime_Type = file.getMimeType();
Logger.log('filename :' filename);
Logger.log('filesize :' filesize);
Logger.log('data :' data);
Logger.log('Mime_Type :' Mime_Type);
var parm_info = [folder_name, Id_Dossier, file_id, filename, filesize, file, data, Mime_Type];
// lancer pour remplacer le contenu de l'image dans le drive pub partage
remplace_file(parm_info);
break;
}
}
}
Logger.log('Fin chercherimage() ');
}
function remplace_file(parm_info) {
// ces variables trouvées
var folder_name_source = parm_info[0];
var Id_Dossier_source = parm_info[1];
var file_id_source = parm_info[2];
var filename_source = parm_info[3];
var filesize_source = parm_info[4];
var file_source = parm_info[5];
var data_source = parm_info[6];
var Mime_Type_source = parm_info[7];
// preparation pour remplacer le contenu de ces variables dans le lien partagé
// aller chercher le dossier partagé : image_partagé
// shared folder ID
var Id_Dossier = '<shared folder id>';
var Dossier_partage = DriveApp.getFolderById(Id_Dossier);
var filesIter = Dossier_partage.getFiles();
var i = 0;
while (filesIter.hasNext()) {
i ;
var file = filesIter.next();
var file_name = file.getName();
var file_id = file.getId();
Logger.log('file_id partage :' file_id);
Logger.log('file_name partage :' file_name);
// à remplacer les contenus des données ...
if (file_name == "test_pub.png") {
var file_resource = {
title: file_name,
mimeType: Mime_Type_source,
driveId: Id_Dossier,
parents: Id_Dossier
};
Drive.Files.update(file_resource, file_id, data_source, {supportsAllDrives:true});
break;
}
}
}
Sample:

Output:

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/444227.html
標籤:谷歌应用脚本
上一篇:Apps腳本“OR”邏輯運算子
