rename or rename the fields of a table
Forums
greetings,
How can I change the names of the fields in a table to be able to export it in excel. Is there any script that can help me.
Thank you
That makes perfect sense,
That makes perfect sense, thanks for letting me know. If you want to do multiple fields you can do something like this:
Set db = Client.OpenDatabase("General Ledger-GL-Database.IMD")
Set task = db.TableManagement
'chang field 1
Set field = db.TableDef.NewField
field.Name = "FIELD1"
field.Description = ""
field.Type = WI_CHAR_FIELD
field.Equation = ""
field.Length = 5
task.ReplaceField "FIELD11", field
task.PerformTask
'chang field 2
Set field = db.TableDef.NewField
field.Name = "FIELD2"
field.Description = ""
field.Type = WI_CHAR_FIELD
field.Equation = ""
field.Length = 5
task.ReplaceField "FIELD22", field
task.PerformTask
'chang field 1
Set field = db.TableDef.NewField
field.Name = "FIELD3"
field.Description = ""
field.Type = WI_CHAR_FIELD
field.Equation = ""
field.Length = 5
task.ReplaceField "FIELD33", field
task.PerformTask
Set task = Nothing
Set db = Nothing
Set field = Nothing
You need to run the PerformTask after each one, if you don't there is a bug and the last field is always really wide for some reason. I don't think they have fixed it because we have the work around.
You can also do this as a loop to save on coding if you want.
If multiple fields are
If multiple fields are renamed I would prefer an extra Sub or Function like that:
 
Sub RenameField(sOldField As String, sNewName As String)
	Set db = Client.CurrentDatabase()
	Set task = db.TableManagement
	Set oOldField = db.TableDef.GetField(sOldField)
	Set field = db.TableDef.NewField
	field.Name = sNewName
	field.Description = oOldField.Description
	field.Type = oOldField.Type
	If oOldField.Type =  WI_CHAR_FIELD Or oOldField.Type = WI_VIRT_CHAR Then
		field.Length = oOldField.Length
		field.Equation = oOldField.Equation
	ElseIf oOldField.Type =  WI_NUM_FIELD Or oOldField.Type = WI_VIRT_NUM Then
		field.Decimals = oOldField.Decimals
		field.Equation = oOldField.Equation
	ElseIf oOldField.Type =  WI_DATE_FIELD Or oOldField.Type = WI_VIRT_DATE Then
		field.Length = oOldField.Length
		field.Equation = oOldField.Equation
	End If
	task.ReplaceField oOldField.Name, field
	task.PerformTask
	Set task = Nothing
	Set db = Nothing
	Set field = Nothing
End Sub
 
         
The easiest way is to just
The easiest way is to just rename a field in your database and then go to the history and grab the IDEAScript code.
Just curious why you need to change the field names for the Excel database?
Here is an example of changing a character fields name: