A1 संकेतन का उपयोग किए बिना Google Apps स्क्रिप्ट कस्टम फ़ंक्शन में पास की सीमा


10

मैं Google Apps स्क्रिप्ट के लिए नया हूं और मैं एक स्प्रेडशीट के लिए एक फ़ंक्शन बनाना चाहता हूं जो सेल वैल्यूज को सम्‍मिलित करता है जब कोशिकाएं कुछ मानदंडों को पूरा करती हैं, जैसे कि पृष्ठभूमि का रंग। इसके अलावा, मैं श्रेणी को एक सरणी के रूप में पास करना चाहता हूं और निम्नलिखित कारण से A1 संकेतन का उपयोग नहीं कर रहा हूं ।

मुझे एक फ़ंक्शन मिला, जो यहां A1 संकेतन का उपयोग करता है । समस्या यह है कि जब मेरे पास किसी दिए गए सेल पर है

=sumWhereBackgroundColorIs("white", "A1:A10")

और मैं मान को सही आसन्न सेल में कॉपी करता हूं परिणाम फिर से होगा

= sumWhereBackgroundColorIs ("सफेद", "A1: A10" )

जबकि मैं करना चाहते हैं

= sumWhereBackgroundColorIs ("सफेद", "बी 1: बी 10" )

अन्यथा मुझे हमेशा इनपुट तर्क को मैन्युअल रूप से संशोधित करना पड़ता है और मैं इससे बचना चाहता हूं क्योंकि मैं इस फ़ंक्शन का बड़े पैमाने पर उपयोग करता हूं।

इसलिए मैंने उपयोग करके मूल्यों की एक सरणी के रूप में एक सीमा पार करके कोशिश की है

=sumIfBgColor(#ffffff, A1:A10)


function sumIfBgColor(color, range){
    var x = 0;
    for(var i = 0; i < range.length; i++){
      for(var j = 0; j < range[i].length; j++){

        var cell = getCell();

        if(cell.getBackgroundColor() == color)
          x += parseFloat(range[i][j]);
      }
    }
    return x;
}

लेकिन मुझे नहीं पता कि मेरे पास जो है उससे शुरू होने वाली सेल (यानी टाइप रेंज की वस्तु) कैसे प्राप्त करें।


यह एपीआई कॉल के उपयोग के बिना संभव नहीं है। यदि ऐसा होता है, तो आपको उपयोग करने की आवश्यकता है A1 notation
जैकब जान तुइंस्ट्रा

मुझे यह कहने से नफरत है, लेकिन जो स्क्रिप्ट आपको मिली वह बहुत कुशल नहीं है। कुछ पंक्तियों पर, अंतर महत्वपूर्ण नहीं हो सकता है, लेकिन यदि आपके पास अधिक पंक्तियाँ हैं, तो 100 का कहना है, तो प्रसंस्करण समय में अंतर बहुत बड़ा है। मेरे द्वारा तैयार की गई स्क्रिप्ट 30x तेज है, क्योंकि यह केवल तीन एपीआई कॉल का उपयोग करती है। आपको मिली स्क्रिप्ट 100 पंक्तियों के लिए उपयोग करती है, लगभग। 300 एपीआई कॉल। मेरा उदाहरण देखें। दिए गए नंबर, मिलीसेकंड हैं।
जैकब जान तुइंस्ट्रा

यह सहायक हो सकता है: webapps.stackexchange.com/a/58179/12075
sanmai

1
इसका उपयोग करने का प्रयास करें: = sumWhereBackgroundColorIs ("सफेद", ADDRESS (ROW (A1), COLUMN (A10), 4) और ":" & ADDRESS (ROW (A10), COLUMN (A10), 4)))
roamer

जवाबों:


8

@ याकूब की असंभवता के दावे के लिए, मैं इस प्रकार उसका खंडन करता हूं ... (लेकिन बेहतर गति के लिए धन्यवाद)

का उपयोग करते हुए:

=sumIfBgColor("#ffffff", A1:A10, COLUMN(A1), ROW(A1))

निम्नलिखित कार्यों के साथ आप क्या चाहते हैं।

/**
 * Sums cell values in a range if they have the given background color
 * 
 * @param  {String} color    Hex string of color eg ("#ffffff")
 * @param  {Array.Array} range    Values of the desired range
 * @param  {int} startcol The column of the range
 * @param  {int} startrow The first row of the range
 * 
 * @return {int}          Sum of all cell values matching the condition
 */
function sumIfBgColor(color, range, startcol, startrow){
  // convert from int to ALPHANUMERIC - thanks to 
  // Daniel at http://stackoverflow.com/a/3145054/2828136
  var col_id = String.fromCharCode(64 + startcol);
  var endrow = startrow + range.length - 1
  // build the range string, then get the background colours
  var range_string = col_id + startrow + ":" + col_id + endrow
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var getColors = ss.getRange(range_string).getBackgrounds();

  var x = 0;
  for(var i = 0; i < range.length; i++) {
    for(var j = 0; j < range[0].length; j++) {
      // Sometimes the cell background is eg 'white' rather than '#ffffff'.
      // I don't know why - I think it's a bug.
      // so we remove that inconsistency with colourNameToHex
      // courtesy of Greg at http://stackoverflow.com/a/1573141/2828136
      if(colourNameToHex(getColors[i][j].toString()) == color) {
        x += range[i][j];
      }
    }
  }
  return x;
}

/**
 * Takes a colour string and returns it to a hex string. If a non-matching string is
 * passed, it will return the argument as is - for this situation it means that a
 * hex string can be passed to it and be returned as is. This is not for production.
 * 
 * @param  {string} color    Must be either a colour name or hex string of color eg ("#ffffff")
 * 
 * @return {object|string}          hex string of color eg ("#ffffff") or the argument given.
 */
function colourNameToHex(colour)
{
    var colours = {"aliceblue":"#f0f8ff","antiquewhite":"#faebd7","aqua":"#00ffff","aquamarine":"#7fffd4","azure":"#f0ffff",
    "beige":"#f5f5dc","bisque":"#ffe4c4","black":"#000000","blanchedalmond":"#ffebcd","blue":"#0000ff","blueviolet":"#8a2be2","brown":"#a52a2a","burlywood":"#deb887",
    "cadetblue":"#5f9ea0","chartreuse":"#7fff00","chocolate":"#d2691e","coral":"#ff7f50","cornflowerblue":"#6495ed","cornsilk":"#fff8dc","crimson":"#dc143c","cyan":"#00ffff",
    "darkblue":"#00008b","darkcyan":"#008b8b","darkgoldenrod":"#b8860b","darkgray":"#a9a9a9","darkgreen":"#006400","darkkhaki":"#bdb76b","darkmagenta":"#8b008b","darkolivegreen":"#556b2f",
    "darkorange":"#ff8c00","darkorchid":"#9932cc","darkred":"#8b0000","darksalmon":"#e9967a","darkseagreen":"#8fbc8f","darkslateblue":"#483d8b","darkslategray":"#2f4f4f","darkturquoise":"#00ced1",
    "darkviolet":"#9400d3","deeppink":"#ff1493","deepskyblue":"#00bfff","dimgray":"#696969","dodgerblue":"#1e90ff",
    "firebrick":"#b22222","floralwhite":"#fffaf0","forestgreen":"#228b22","fuchsia":"#ff00ff",
    "gainsboro":"#dcdcdc","ghostwhite":"#f8f8ff","gold":"#ffd700","goldenrod":"#daa520","gray":"#808080","green":"#008000","greenyellow":"#adff2f",
    "honeydew":"#f0fff0","hotpink":"#ff69b4",
    "indianred ":"#cd5c5c","indigo ":"#4b0082","ivory":"#fffff0","khaki":"#f0e68c",
    "lavender":"#e6e6fa","lavenderblush":"#fff0f5","lawngreen":"#7cfc00","lemonchiffon":"#fffacd","lightblue":"#add8e6","lightcoral":"#f08080","lightcyan":"#e0ffff","lightgoldenrodyellow":"#fafad2",
    "lightgrey":"#d3d3d3","lightgreen":"#90ee90","lightpink":"#ffb6c1","lightsalmon":"#ffa07a","lightseagreen":"#20b2aa","lightskyblue":"#87cefa","lightslategray":"#778899","lightsteelblue":"#b0c4de",
    "lightyellow":"#ffffe0","lime":"#00ff00","limegreen":"#32cd32","linen":"#faf0e6",
    "magenta":"#ff00ff","maroon":"#800000","mediumaquamarine":"#66cdaa","mediumblue":"#0000cd","mediumorchid":"#ba55d3","mediumpurple":"#9370d8","mediumseagreen":"#3cb371","mediumslateblue":"#7b68ee",
    "mediumspringgreen":"#00fa9a","mediumturquoise":"#48d1cc","mediumvioletred":"#c71585","midnightblue":"#191970","mintcream":"#f5fffa","mistyrose":"#ffe4e1","moccasin":"#ffe4b5",
    "navajowhite":"#ffdead","navy":"#000080",
    "oldlace":"#fdf5e6","olive":"#808000","olivedrab":"#6b8e23","orange":"#ffa500","orangered":"#ff4500","orchid":"#da70d6",
    "palegoldenrod":"#eee8aa","palegreen":"#98fb98","paleturquoise":"#afeeee","palevioletred":"#d87093","papayawhip":"#ffefd5","peachpuff":"#ffdab9","peru":"#cd853f","pink":"#ffc0cb","plum":"#dda0dd","powderblue":"#b0e0e6","purple":"#800080",
    "red":"#ff0000","rosybrown":"#bc8f8f","royalblue":"#4169e1",
    "saddlebrown":"#8b4513","salmon":"#fa8072","sandybrown":"#f4a460","seagreen":"#2e8b57","seashell":"#fff5ee","sienna":"#a0522d","silver":"#c0c0c0","skyblue":"#87ceeb","slateblue":"#6a5acd","slategray":"#708090","snow":"#fffafa","springgreen":"#00ff7f","steelblue":"#4682b4",
    "tan":"#d2b48c","teal":"#008080","thistle":"#d8bfd8","tomato":"#ff6347","turquoise":"#40e0d0",
    "violet":"#ee82ee",
    "wheat":"#f5deb3","white":"#ffffff","whitesmoke":"#f5f5f5",
    "yellow":"#ffff00","yellowgreen":"#9acd32"};

    if (typeof colours[colour.toLowerCase()] != 'undefined')
        return colours[colour.toLowerCase()];

    return colour;
}

1
बस कोशिश की और यह काम करता है। वेब एप्लिकेशन पर यह उत्तर देना बहुत अच्छा है।
जैकब जान टुंस्ट्रा

2
मैं इन चीजों का परीक्षण करता हूं, आप जानते हैं। ;-)
टॉम होरवुड

धन्यवाद pnuts - बस मेरे पुराने उत्तर के माध्यम से पढ़ रहा था और सोचा था कि थोड़ा सा रंग मदद कर सकता है (मुझे लगता है कि यह हालांकि नहीं होगा)। क्षमा करें, जिसे सभी को नोटपैड शैली के उत्तरों को पढ़ना है :-)
टॉम होरवुड

2

संदर्भ: http://igoogledrive.blogspot.com/2015/11/google-spreadsheet-sum-of-colored-cells.html

कस्टम फ़ंक्शन को स्ट्रिंग के रूप में मापदंडों को पारित करने के बजाय, निम्न स्क्रिप्ट एक सीमा के रूप में इनपुट लेती है:

/**
* @param {string} color String as background color to be searched for in sumRange
* @param {range} sumRange Range to be evaluated
* @return {number}
* @customfunction
*/

function sumColoredCells(color,sumRange) {
  var activeRange = SpreadsheetApp.getActiveRange();
  var activeSheet = activeRange.getSheet();
  var formula = activeRange.getFormula();
  var rangeA1Notation = formula.match(/\,(.*)\)/).pop();
  var range = activeSheet.getRange(rangeA1Notation);
  var bg = range.getBackgrounds();
  var values = range.getValues();
  var total = 0;

  for(var i=0;i<bg.length;i++)
    for(var j=0;j<bg[0].length;j++)
      if( bg[i][j] == color )
        total=total+(values[i][j]*1);
  return total;
};

निम्नलिखित स्क्रीनशॉट पर एक नज़र है:

यहाँ छवि विवरण दर्ज करें


1

निम्न लिपि पटकथा को करेगी।

कोड

function sumIfBgColor(color, range){
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var getColors = ss.getRange(range).getBackgrounds();
  var getValues = ss.getRange(range).getValues(), x = 0;
  for(var i = 0; i < getValues.length; i++) {
    for(var j = 0; j < getValues[0].length; j++) {
      if(getColors[i][j].toString() == color) {
        x += getValues[i][j];
      }
    }
  }
  return x;
}

व्याख्या की

सबसे पहले, सक्रिय स्प्रेडशीट निर्धारित की जाती है। फिर रेंज के आधार पर मूल्य और रंग दोनों प्राप्त होते हैं। मूल्यों को रंगों के माध्यम से पुनरावृत्त करने के लिए और अंत में संक्षेपण के लिए उपयोग किया जाएगा।

प्रयोग

यहाँ छवि विवरण दर्ज करें

उदाहरण

मैंने आपके लिए एक उदाहरण फ़ाइल बनाई है: पृष्ठभूमि पर आधारित योग


1
यह कार्य करता है, लेकिन आपको इसे A1 संकेतन के साथ कॉल करना होगा, अर्थात सेल पर लिखना = sumIfBgColor (#ffffff, "A1: A10") यह मेरे द्वारा ऊपर लिखी गई आवश्यकताओं के अनुरूप नहीं है, अर्थात् कॉपी करते समय और कॉपी करें मुझे सामग्री को मैन्युअल रूप से संपादित करना होगा
GEN

@ अपने प्रश्न के लिए अपनी टिप्पणी में, मैंने पहले ही उल्लेख किया है कि यह संभव नहीं है। कोड जिसे आपने A1 नोटेशन के साथ या उसके बिना काम नहीं करना चाहिए था। इसलिए मैंने एक पटकथा लिखी जो करती है।
जैकब जान टुंस्ट्रा

क्षमा करें, मैंने आपकी टिप्पणी नहीं पढ़ी। इतनी बुरी खबर! तो कोई रास्ता नहीं है..मैं A1 संकेतन का उपयोग नहीं कर सकता, मुझे अपनी स्प्रेडशीट के लेआउट को पूरी तरह से बदलना होगा। धन्यवाद
Ganswer

@ क्या आपने हालांकि मेरे उत्तर को उपयोगी पाया?
जैकब जान टुंस्ट्रा

1
यह एक अच्छा विकल्प है लेकिन मेरे पास पहले से ही एक समान फ़ंक्शन था जो A1 संकेतन के साथ काम करता है। कृपया अपने उत्तर को शीर्ष पर सहित एक टिप्पणी में यह कहते हुए संशोधित करें कि मैं जो
खोजता
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.