# Converting Strings to Numbers

## Recommended Posts

Hello Marionette lovers !

Is there anyway using existing nodes to convert strings (like the ones coming from the GetIFC Pset Value ... and many others from IPFC parameters...) into a number or Integer ?

Maybe the node Function could do this trick  ? (but was not capable to implement this properly ...) ?

Thanks for your valued inputs !

If the string is composed of entirely numbers, you can run it through the "float" node. It's a little trickier if you have units in the string, though, and those would require special handling.

Ok... got it. Tks Marissa !

Yes... i think that in case we do have units involved we better trying creating a custom node and do things in Python instead ... right ?

I would take the Function Node and use the formula x[:-2] (to remove the last to items of the string, or x[:-1] to remove the last one etc.). There will be other possibilities with other nodes but I first had to search the right ones.

Yeah, that worked too ... Thanks Dom !

Hello DomC

How does it work ?

Can I use it in the Datenmanager ?

I would like to display 0.30 instead of 0.30000000

Do I make something wrong ?

I try in Node

area = vs.Round(vs.GetObjectVariableReal(obj,608)/0.01) * 0.01

by doing *0.01 the zeros come again....

Hi

Generally this are common issues:

1. If you have a String of 0.30000 and want to have have a string output from 0.30 you can youse x[:4]. The first 4 character of the string. If you have 100.45987 you will get 100. with this formula. If you use x[:-2] the last two characters are lost. To Prevent this, you could first split the string in number and digit and then operate with this.

2. Sometimes there are Units like m2 mm m qm etc.

3. Sometimes we want to have prefix like +. - and +- etc.

4. Sometimes there are , instead . of decimal seperators.

The attached Nodes, addresses all of this common issues. Simple issues, but relatively complexe to solve. I attached some node to solve them.

The error message you got is because to substract two items from a list (a string is like a list  '0', '.', '0', '0' etc. or a list of numbers will be [0,5,3,4.5,]). So with a Number of 0.30000 it will not work, this is just one item. You could convert to string str(x)[:-2]. Then it would work. Do not know what mapping is doing. If it converts the string of 0.3 in a number it Maybe by standard makes again 0.300000 in the IFC Export.

You see, not so trivial. I Recommend using the Attached Node Digits from string and try with this.

Set Digits From String.vwx

Thank you very much for your help...

I have another question:

How can I use the Node "Objs by Crit" for a Column ?

PON='Column' or T=Column  PON='Säule'

doesn't work...

The same question for a Door / Window / Fassade !?

Thank you so much for your Help...

In 2019, the Objects by Criteria node has a button below it allowing you to define the Criteria using a dialog.

When I placed a column in my document and used that button, I was given

`((PON='Column2'))`

as my criteria.

If you are not seeing the button in the Object Info Palette with the Objs by Crit node selected, please replace the existing node with a new one from default content.

Thanks a lot,

That will make my life easier 😃

Regards

it's me again,

😃

How can I create a node with

object.OA Height

Shaft Depth

Shaft Width

??

Thanks a lot

Here's a short network that returns these values.

Often, values for Parametric Objects are stored in hidden records - this demonstrates how to extract the ones you've asked for.

Record fields are returned as strings (text), so they will need to be converted to numbers if you plan to use them elsewhere.

If you want to assign values to the object, you would instead use the Set Record Field node.

Marionette_ReturnColumnInfo_MFarrell.vwx

and how do you convert String to Numbers ? so could I use the div node...

I need the 0.25 instead of 2.5e-01m or 2.5

sorry I found the "Float" node...

Thanks again for your Help !!

## Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

×   Pasted as rich text.   Restore formatting

Only 75 emoji are allowed.

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×