#1   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 15
Default UDF

I found several UDF's on the internet to do what I want them to do. My
question is none of them work and I have tried one that I know to have
worked yesterday but not today on any of my computers, I tried
recalculating the worksheet and everything. Any help would be greatly
appreciated.

thanks
Glenn

  #2   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 3,101
Default UDF

may your events are disabled try running this code to turn then back on
Sub enableEvents()
Application.enableEvents = True
End Sub

"QTGlennM" wrote:

I found several UDF's on the internet to do what I want them to do. My
question is none of them work and I have tried one that I know to have
worked yesterday but not today on any of my computers, I tried
recalculating the worksheet and everything. Any help would be greatly
appreciated.

thanks
Glenn


  #3   Report Post  
Posted to microsoft.public.excel.programming
Tim Tim is offline
external usenet poster
 
Posts: 145
Default UDF

Almost impossible to help without seeing any code...

Tim

"QTGlennM" wrote in message
oups.com...
I found several UDF's on the internet to do what I want them to do. My
question is none of them work and I have tried one that I know to have
worked yesterday but not today on any of my computers, I tried
recalculating the worksheet and everything. Any help would be greatly
appreciated.

thanks
Glenn



  #4   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 3,440
Default UDF

Hi Glenn,

What does "not work" mean? Wrong result? #NAME error? Other error? Excel crashing?

Please be more specific; show the code of the functions, where you paste it, how you call it, value of the arguments, expected
result and what you got instead, etc.

--
Kind regards,

Niek Otten
Microsoft MVP - Excel

"QTGlennM" wrote in message oups.com...
|I found several UDF's on the internet to do what I want them to do. My
| question is none of them work and I have tried one that I know to have
| worked yesterday but not today on any of my computers, I tried
| recalculating the worksheet and everything. Any help would be greatly
| appreciated.
|
| thanks
| Glenn
|


  #5   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 15
Default UDF

On Jun 2, 7:13 am, "Niek Otten" wrote:
Hi Glenn,

What does "not work" mean? Wrong result? #NAME error? Other error? Excel crashing?

Please be more specific; show the code of the functions, where you paste it, how you call it, value of the arguments, expected
result and what you got instead, etc.

--
Kind regards,

Niek Otten
Microsoft MVP - Excel

"QTGlennM" wrote in ooglegroups.com...

|I found several UDF's on the internet to do what I want them to do. My
| question is none of them work and I have tried one that I know to have
| worked yesterday but not today on any of my computers, I tried
| recalculating the worksheet and everything. Any help would be greatly
| appreciated.
|
| thanks
| Glenn
|


Here is the code. I got it from the internet. It has worked for me
before. And other UDF's as well now none of them work at all.

Function ExtractElement(str, N, sepChar)
' Returns the nth element from a string,
' using a specified separator character
Dim x As Variant
x = Split(str, sepChar)
If N 0 And N - 1 <= UBound(x) Then
ExtractElement = x(N - 1)
Else
ExtractElement = ""
End If
End Function

Here is formula that I use.
=ExtractElement(A1,2,".")

Here is the Error
#NAME?

Any help would be awsome. Thanks for everything.

Glenn



  #6   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 5
Default UDF

The information that it returns #NAME? tells us that Excel cannot see your
UDF from the Workbook that you are using.

There could be one of several issues at play here... but provide us with a
bit more info first.

Where is the UDF code? Is it within the same Workbook that the formula
using it resides? It doesn't sound like it. Perhaps you put it in a
different Workbook or addin? Make sure that when you open up your Workbook
and go into the code IDE (ALT-F11) that your function is entered in a Module
or Sheet from your Workbook and that it is marked Public as the access
modifier.

If these items are true, report back to us, as there might be a different
reference issue at hand.

-putman
  #7   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 3,440
Default UDF

Hi Glenn,

You didn't even answer half of my questions.
Nevertheless;
You may have pasted the function in a Worksheet or Workbook module.
However, it has to be pasted into a Standard module; In the VBE: InsertModule

--
Kind regards,

Niek Otten
Microsoft MVP - Excel


"QTGlennM" wrote in message ups.com...
| On Jun 2, 7:13 am, "Niek Otten" wrote:
| Hi Glenn,
|
| What does "not work" mean? Wrong result? #NAME error? Other error? Excel crashing?
|
| Please be more specific; show the code of the functions, where you paste it, how you call it, value of the arguments, expected
| result and what you got instead, etc.
|
| --
| Kind regards,
|
| Niek Otten
| Microsoft MVP - Excel
|
| "QTGlennM" wrote in ooglegroups.com...
|
| |I found several UDF's on the internet to do what I want them to do. My
| | question is none of them work and I have tried one that I know to have
| | worked yesterday but not today on any of my computers, I tried
| | recalculating the worksheet and everything. Any help would be greatly
| | appreciated.
| |
| | thanks
| | Glenn
| |
|
| Here is the code. I got it from the internet. It has worked for me
| before. And other UDF's as well now none of them work at all.
|
| Function ExtractElement(str, N, sepChar)
| ' Returns the nth element from a string,
| ' using a specified separator character
| Dim x As Variant
| x = Split(str, sepChar)
| If N 0 And N - 1 <= UBound(x) Then
| ExtractElement = x(N - 1)
| Else
| ExtractElement = ""
| End If
| End Function
|
| Here is formula that I use.
| =ExtractElement(A1,2,".")
|
| Here is the Error
| #NAME?
|
| Any help would be awsome. Thanks for everything.
|
| Glenn
|


  #8   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 2,202
Default UDF

Here is the code. I got it from the internet. It has worked for me
before. And other UDF's as well now none of them work at all.

Function ExtractElement(str, N, sepChar)
' Returns the nth element from a string,
' using a specified separator character
Dim x As Variant
x = Split(str, sepChar)
If N 0 And N - 1 <= UBound(x) Then
ExtractElement = x(N - 1)
Else
ExtractElement = ""
End If
End Function


Do you know you can do what this function does right in VBA? This one line
will do what the function you posted does...

ExtractedElement = Split(StringIn, DelimiterString)(ItemNumber-1)

(minus the error checking, of course) where StringIn is the original string
you want to split apart, DelimiterString is the delimiter used to separate
your items and ItemNumber is the item in the series that you want, counting
the first item as number one. Here is the one-liner above as a function,
with error checking and using the same argument list as your posted function
(so you won't have to change any existing code)...

Function ExtractElement(str, N, sepChar) As String
On Error Resume Next
ExtractElement = Split(str, sepChar)(N - 1)
End Function


Rick

  #9   Report Post  
Posted to microsoft.public.excel.programming
external usenet poster
 
Posts: 15
Default UDF

On Jun 2, 5:39 pm, "Rick Rothstein \(MVP - VB\)"
wrote:
Here is the code. I got it from the internet. It has worked for me
before. And other UDF's as well now none of them work at all.


Function ExtractElement(str, N, sepChar)
' Returns the nth element from a string,
' using a specified separator character
Dim x As Variant
x = Split(str, sepChar)
If N 0 And N - 1 <= UBound(x) Then
ExtractElement = x(N - 1)
Else
ExtractElement = ""
End If
End Function


Do you know you can do what this function does right in VBA? This one line
will do what the function you posted does...

ExtractedElement = Split(StringIn, DelimiterString)(ItemNumber-1)

(minus the error checking, of course) where StringIn is the original string
you want to split apart, DelimiterString is the delimiter used to separate
your items and ItemNumber is the item in the series that you want, counting
the first item as number one. Here is the one-liner above as a function,
with error checking and using the same argument list as your posted function
(so you won't have to change any existing code)...

Function ExtractElement(str, N, sepChar) As String
On Error Resume Next
ExtractElement = Split(str, sepChar)(N - 1)
End Function

Rick


Thank you guys for all the advice. I opened a new workbook and pasted
the code into a new module as suggested. It then worked. I apologize
for not being specific I am very very new at this, and you all helped
me a great deal. I thank you for your patience. Thank you so so
much.!!!!

Glenn

Reply
Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules

Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On



All times are GMT +1. The time now is 10:07 PM.

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Copyright ©2004-2025 ExcelBanter.
The comments are property of their posters.
 

About Us

"It's about Microsoft Excel"