17
votes

I have a few Simple Custom Functions that I use all the time. I have recently run into a spreadsheet that I desperately need to use them in, but when I try to use even the most basic custom functions, I get "#NAME?" with a hover text of "unknown function".

Even deleting all other code, and trying just this simple function, doesn't seem to work:

function double(d) {
  return 2*d;
}

When I duplicate the spreadsheet, the code that comes with it DOES work.

A few Notes:

  1. This is a Google Apps for Enterprise account.

  2. I was originally not the owner on this spreadsheet, but have since become the owner, thinking that this might be the cause.

  3. The spreadsheet originally had protected regions, which have since been removed, thinking that this might be the cause.

This spreadsheet is shared with hundreds of people, so I really want to find the root cause and fix it.

Any thoughts?

9
Check for the sillies first. Is the code in an .html file instead of a .gs file? Are you editing a script that's in a different spreadsheet? Are the custom functions you are interested in contained inside another function (thus hiding them)? Did you save the script? Can you run double() from within the debugger?Mogsdad
All the sillies checked - it is a .gs, it is in the correct spreadsheet, it is a root level function, it is saved, it can be run in the debugger, permissions have been granted to the doc, etc. Last Note - I can simply duplicate the spreadsheet, and in the duplicate, all custom functions duplicate work as expected.Bob Wold
Instead of a programming problem this looks to be a problem with the spreadsheet file and you should ask for help to Google Apps for Work support, but this could be very likely that the solution will be to use another file.Rubén
Hi! I delete the content of the array sheets.macros (where there were some test macros) and it start working.ESL

9 Answers

4
votes

Way too late for the OP, but in case this helps someone else: I had a similar issue where my spreadsheet suddenly stopped recognising custom functions that have been working for months. No code changes have been made recently and the spreadsheet hadn't even been edited since it last worked. When I went to Tools > Script editor it still showed the code with the custom functions.

Reloading the page and closing and reopening didn't fix it. I added a simple parameterless wrapper function to call the custom function with some appropriate arguments.

I then ran this wrapper function in the debugger with a breakpoint in the original custom function. When it hit this, I switched back to the spreadsheet and it could magically see the custom functions again.

4
votes

If you already published as Add-on, then you need to do reactivate the addon for copied sheet with the following steps:

  • Click the menu Add-ons / YOUR-ADD-ON-NAME / Help / View in store,
  • click Manage and in the dropdown menu uncheck then check the 'Use in this document' again for the addon to be loaded to the current sheet.
3
votes

I can not explain the exact cause, but here is a SOLUTION:

  1. copy the expression written in the cell
  2. delete the content of the cell
  3. re-enter the expression in the cell!
2
votes

Again, late in the thread, but it was the only thread I found on this -- My function had been running well, too and suddenly returned Unknown Function. I found that the signature had changed - initially, I had a few parameters I was sending in and the cell returning the error still had parameters in the function call. The function hadn't used parameters for a long time. I removed the parameters and Voila! Apparently, something changed where it started enforcing call patterns...

1
votes

When you have custom functions on a sheet - they areBOUND to that sheet. So it does work when you duplicate the sheet itself , but it does not automatically become a global or domain wide custom function.

The only way use it else where without actually publishing it as an add-on is to go to the tools menu, click on script editor and actually copy the code from the script bound to that sheet that it works with, then paste it in the script editor of the sheet you want to use it in.

1
votes

I faced the same problems. I here document, what worked for me.

To create a new custom function, I did the following:

  1. In spreadsheet: Menu -> Tools -> Script Editor
  2. Wrote the function in Script Editor
  3. In spreadsheet: Menu -> Tools -> Import -> Clicked "Add Function" next to the custom function name.
  4. In spreadsheet: In a cell, I did =CustomFunctionName()

This worked.

Now, when I wanted to reuse the same in another spreadsheet, there are 2 ways to do that.

  1. Make Copy of the sheet in which the custom function is written.
  2. Make library of custom functions and reuse them in other sheets, by writing custom functions specific for a particular sheet.

#1 Make Copy of the sheet in which the custom function is written.

In this way, the whole custom function code gets duplicated. So, if any changes needs to be done in the custom function, the change must be done in all the copied files. Also, once the sheet is copied, the custom function does not simply works. I had to delete the cells & reenter the function names again, to get them working.

#2 Make library of custom functions and reuse them in other sheets, by writing custom functions specific for a particular sheet.

This is better, because, the core logic will stay in one place. Only wrapper functions will be written for each sheet, in which the custom functions are used.

To create a library:

  1. Write the function in Script Editor
  2. Click on "Deploy -> New Deployment"
  3. "Select Type -> Library"
  4. Provide a description, if you want to and click "Deploy" & "Done"
  5. Click on the "Project Settings" on the left menu & copy the "Script Id"(to use the library)

To use a library:

  1. Goto the spreadsheet where you want the library to be used.
  2. Menu -> Tools -> Script Editor
  3. In Script Editor: Click + button next to the Library section on the left.
  4. Enter the "Script Id" & Click on "Look Up".
  5. You will see the script details. Then click on the "Add" button.
  6. Remember the "Identifier" field value. Using that, the functions of the library can be accessed.
  7. Now, in the Script Editor, you can call the library functions with the identifier name. See examples below.

Library Code:

function SheetName() {
  return SpreadsheetApp.getActiveSpreadsheet().getName();
}

function SayHello(name) {
  return 'Hello ${name}';
}

Let's say, while including this library into a spreadsheet, I entered the identifier as utility. So, in the script editor, I would write like this:

function SheetName() {
  return utility.SheetName();
}

How to update a library and use the updated code in spreadsheets?

To update a library:

  1. Make the changes in the library project.
  2. Click on "Deploy -> Manage Deployments".
  3. Select the correct deployment from the left side.
  4. Click on the edit button(on top left).
  5. Select "New Version" in the "Version" input.
  6. Click "Deploy" & make note of the new version number displayed.

To use the updated library:

  1. Goto the spreadsheet in which the library is already being used & open the Script Editor in there.
  2. If the Script Editor of that sheet is already open, reload the page once.
  3. Click on the library name in the Library section(on the left).
  4. Select the latest version number on the Version input & click "Save".

Now, you can call the new functions in the same way you did previously & the existing functions will work in the new way(if there are any changes to the existing functions).

0
votes

I faced exactly the same problem ! My code worked well and was properly linked to the correct spreadsheet. Unfortunately deleting the content of the cell didn't work for me.

Another solution I found is to simply rename the function.

For example: "myFunction" renamed as "my_Function" and it worked for me ! I guess maybe it's due to an important amount of calls (over 35 000 in my case). Maybe it makes it run into an error or something. Cheers !

0
votes

I created a copy of my sheet as a backup and closed up for the night. I came back in the morning with the functions unable to be called. So I did the usual, cut the function from the cell and pasted it right back. This usually fixed things. Not this time. Tried reopening browser, tried re-logging in. Nothing worked. Than I simply renamed the function in the Project Editor (appended "call" in front of the function name) and edited the sheet to match. It just worked.

-1
votes

Another late entry. This error can also come as a signature violation. This can occur if the type of variable being passed into the custom function is different from what is expected. I was "cleaning up" my spreadsheet and re-formatted some of the entries. This caused a not found. Detecting this error is made easy if you enabled the function for prompting. In my case I started typing the function name and it came up (so Google knew it was there), but when it came to execution I got the error.