How to delete a chart using google script?












-1















I wrote a script to automatically generate charts from data on different tabs (after clicking a button on a new sheet).



I would now like to add a "reset" button which will automatically delete or remove the generated charts (so I can generate different charts with another button).



Can anyone help on how I can do this? I've tried the below, but to no avail....



function Finance_clear() {

function deleteAllChartsFromSheet(sheetName) {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var chartsSheet = ss.getSheetByName(sheetName);
var n = chartsSheet.getCharts().length;
for (var i = n-1; i >= 0; i--) {
var chart = chartsSheet.getCharts()[i];
chartsSheet.removeChart(chart);
}
}
};









share|improve this question



























    -1















    I wrote a script to automatically generate charts from data on different tabs (after clicking a button on a new sheet).



    I would now like to add a "reset" button which will automatically delete or remove the generated charts (so I can generate different charts with another button).



    Can anyone help on how I can do this? I've tried the below, but to no avail....



    function Finance_clear() {

    function deleteAllChartsFromSheet(sheetName) {
    var ss = SpreadsheetApp.getActiveSpreadsheet();
    var chartsSheet = ss.getSheetByName(sheetName);
    var n = chartsSheet.getCharts().length;
    for (var i = n-1; i >= 0; i--) {
    var chart = chartsSheet.getCharts()[i];
    chartsSheet.removeChart(chart);
    }
    }
    };









    share|improve this question

























      -1












      -1








      -1








      I wrote a script to automatically generate charts from data on different tabs (after clicking a button on a new sheet).



      I would now like to add a "reset" button which will automatically delete or remove the generated charts (so I can generate different charts with another button).



      Can anyone help on how I can do this? I've tried the below, but to no avail....



      function Finance_clear() {

      function deleteAllChartsFromSheet(sheetName) {
      var ss = SpreadsheetApp.getActiveSpreadsheet();
      var chartsSheet = ss.getSheetByName(sheetName);
      var n = chartsSheet.getCharts().length;
      for (var i = n-1; i >= 0; i--) {
      var chart = chartsSheet.getCharts()[i];
      chartsSheet.removeChart(chart);
      }
      }
      };









      share|improve this question














      I wrote a script to automatically generate charts from data on different tabs (after clicking a button on a new sheet).



      I would now like to add a "reset" button which will automatically delete or remove the generated charts (so I can generate different charts with another button).



      Can anyone help on how I can do this? I've tried the below, but to no avail....



      function Finance_clear() {

      function deleteAllChartsFromSheet(sheetName) {
      var ss = SpreadsheetApp.getActiveSpreadsheet();
      var chartsSheet = ss.getSheetByName(sheetName);
      var n = chartsSheet.getCharts().length;
      for (var i = n-1; i >= 0; i--) {
      var chart = chartsSheet.getCharts()[i];
      chartsSheet.removeChart(chart);
      }
      }
      };






      google-apps-script






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 15 '18 at 17:03









      Hyder WHyder W

      66




      66
























          1 Answer
          1






          active

          oldest

          votes


















          0














          Delete All Charts from a Sheet



          function delAllChartsFromSheet(name) {
          var ss=SpreadsheetApp.getActive();
          var sh=ss.getSheetByName(name);
          var chts=sh.getCharts();
          for(var i=0;i<chts.length;i++){
          sh.removeChart(chts[i]);
          }
          }


          Sheet Reference






          share|improve this answer
























          • This isn't working. Should my spreadsheet name go where you have "(name)"? Should it just be entered with a single quote around it?

            – Hyder W
            Nov 16 '18 at 23:07











          • name is the sheet name.

            – Cooper
            Nov 17 '18 at 1:51











          • This worked: function clear() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getSheets()[0]; // This removes all the embedded charts from the spreadsheet var charts = sheet.getCharts(); for (var i in charts) { sheet.removeChart(charts[i]); } } ; The sheet that you want the charts to be removed/deleted will need to be the first sheet (tab) in your spreadsheet

            – Hyder W
            Nov 20 '18 at 15:27













          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53324528%2fhow-to-delete-a-chart-using-google-script%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          0














          Delete All Charts from a Sheet



          function delAllChartsFromSheet(name) {
          var ss=SpreadsheetApp.getActive();
          var sh=ss.getSheetByName(name);
          var chts=sh.getCharts();
          for(var i=0;i<chts.length;i++){
          sh.removeChart(chts[i]);
          }
          }


          Sheet Reference






          share|improve this answer
























          • This isn't working. Should my spreadsheet name go where you have "(name)"? Should it just be entered with a single quote around it?

            – Hyder W
            Nov 16 '18 at 23:07











          • name is the sheet name.

            – Cooper
            Nov 17 '18 at 1:51











          • This worked: function clear() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getSheets()[0]; // This removes all the embedded charts from the spreadsheet var charts = sheet.getCharts(); for (var i in charts) { sheet.removeChart(charts[i]); } } ; The sheet that you want the charts to be removed/deleted will need to be the first sheet (tab) in your spreadsheet

            – Hyder W
            Nov 20 '18 at 15:27


















          0














          Delete All Charts from a Sheet



          function delAllChartsFromSheet(name) {
          var ss=SpreadsheetApp.getActive();
          var sh=ss.getSheetByName(name);
          var chts=sh.getCharts();
          for(var i=0;i<chts.length;i++){
          sh.removeChart(chts[i]);
          }
          }


          Sheet Reference






          share|improve this answer
























          • This isn't working. Should my spreadsheet name go where you have "(name)"? Should it just be entered with a single quote around it?

            – Hyder W
            Nov 16 '18 at 23:07











          • name is the sheet name.

            – Cooper
            Nov 17 '18 at 1:51











          • This worked: function clear() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getSheets()[0]; // This removes all the embedded charts from the spreadsheet var charts = sheet.getCharts(); for (var i in charts) { sheet.removeChart(charts[i]); } } ; The sheet that you want the charts to be removed/deleted will need to be the first sheet (tab) in your spreadsheet

            – Hyder W
            Nov 20 '18 at 15:27
















          0












          0








          0







          Delete All Charts from a Sheet



          function delAllChartsFromSheet(name) {
          var ss=SpreadsheetApp.getActive();
          var sh=ss.getSheetByName(name);
          var chts=sh.getCharts();
          for(var i=0;i<chts.length;i++){
          sh.removeChart(chts[i]);
          }
          }


          Sheet Reference






          share|improve this answer













          Delete All Charts from a Sheet



          function delAllChartsFromSheet(name) {
          var ss=SpreadsheetApp.getActive();
          var sh=ss.getSheetByName(name);
          var chts=sh.getCharts();
          for(var i=0;i<chts.length;i++){
          sh.removeChart(chts[i]);
          }
          }


          Sheet Reference







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Nov 15 '18 at 21:50









          CooperCooper

          7,7842729




          7,7842729













          • This isn't working. Should my spreadsheet name go where you have "(name)"? Should it just be entered with a single quote around it?

            – Hyder W
            Nov 16 '18 at 23:07











          • name is the sheet name.

            – Cooper
            Nov 17 '18 at 1:51











          • This worked: function clear() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getSheets()[0]; // This removes all the embedded charts from the spreadsheet var charts = sheet.getCharts(); for (var i in charts) { sheet.removeChart(charts[i]); } } ; The sheet that you want the charts to be removed/deleted will need to be the first sheet (tab) in your spreadsheet

            – Hyder W
            Nov 20 '18 at 15:27





















          • This isn't working. Should my spreadsheet name go where you have "(name)"? Should it just be entered with a single quote around it?

            – Hyder W
            Nov 16 '18 at 23:07











          • name is the sheet name.

            – Cooper
            Nov 17 '18 at 1:51











          • This worked: function clear() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getSheets()[0]; // This removes all the embedded charts from the spreadsheet var charts = sheet.getCharts(); for (var i in charts) { sheet.removeChart(charts[i]); } } ; The sheet that you want the charts to be removed/deleted will need to be the first sheet (tab) in your spreadsheet

            – Hyder W
            Nov 20 '18 at 15:27



















          This isn't working. Should my spreadsheet name go where you have "(name)"? Should it just be entered with a single quote around it?

          – Hyder W
          Nov 16 '18 at 23:07





          This isn't working. Should my spreadsheet name go where you have "(name)"? Should it just be entered with a single quote around it?

          – Hyder W
          Nov 16 '18 at 23:07













          name is the sheet name.

          – Cooper
          Nov 17 '18 at 1:51





          name is the sheet name.

          – Cooper
          Nov 17 '18 at 1:51













          This worked: function clear() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getSheets()[0]; // This removes all the embedded charts from the spreadsheet var charts = sheet.getCharts(); for (var i in charts) { sheet.removeChart(charts[i]); } } ; The sheet that you want the charts to be removed/deleted will need to be the first sheet (tab) in your spreadsheet

          – Hyder W
          Nov 20 '18 at 15:27







          This worked: function clear() { var ss = SpreadsheetApp.getActiveSpreadsheet(); var sheet = ss.getSheets()[0]; // This removes all the embedded charts from the spreadsheet var charts = sheet.getCharts(); for (var i in charts) { sheet.removeChart(charts[i]); } } ; The sheet that you want the charts to be removed/deleted will need to be the first sheet (tab) in your spreadsheet

          – Hyder W
          Nov 20 '18 at 15:27






















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53324528%2fhow-to-delete-a-chart-using-google-script%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Xamarin.iOS Cant Deploy on Iphone

          Glorious Revolution

          Dulmage-Mendelsohn matrix decomposition in Python