?
Solved

Openoffice.org 3.0 macro

Posted on 2009-04-07
1
Medium Priority
?
1,818 Views
Last Modified: 2013-12-27
Need to write a macro in OpenOffice.org version 3 that selects all of column A, copies all data in column A and then pastes over data in column A with TEXT.

My column A contains an equation, and when I am done with the calculations, I need a macro that will overwrite the equations with their current value.  I tried the record macro and ended up with the following code.  

When I originally did the Paste Special (while recording the macro), it worked and I ended up with only values in Column A.  But when I run the macro, it pastes the formulas, not the text into Column A.  Any help is appreciated.
sub resolved3
rem ----------------------------------------------------------------------
rem define variables
dim document   as object
dim dispatcher as object
rem ----------------------------------------------------------------------
rem get access to the document
document   = ThisComponent.CurrentController.Frame
dispatcher = createUnoService("com.sun.star.frame.DispatchHelper")
 
rem ----------------------------------------------------------------------
dim args1(0) as new com.sun.star.beans.PropertyValue
args1(0).Name = "ToPoint"
args1(0).Value = "$A$2"
 
dispatcher.executeDispatch(document, ".uno:GoToCell", "", 0, args1())
 
rem ----------------------------------------------------------------------
dim args2(0) as new com.sun.star.beans.PropertyValue
args2(0).Name = "ToPoint"
args2(0).Value = "$A$1"
 
dispatcher.executeDispatch(document, ".uno:GoToCell", "", 0, args2())
 
rem ----------------------------------------------------------------------
dispatcher.executeDispatch(document, ".uno:Copy", "", 0, Array())
 
rem ----------------------------------------------------------------------
dim args4(5) as new com.sun.star.beans.PropertyValue
args4(0).Name = "Flags"
args4(0).Value = "S"
args4(1).Name = "FormulaCommand"
args4(1).Value = 0
args4(2).Name = "SkipEmptyCells"
args4(2).Value = false
args4(3).Name = "Transpose"
args4(3).Value = false
args4(4).Name = "AsLink"
args4(4).Value = false
args4(5).Name = "MoveMode"
args4(5).Value = 4
 
dispatcher.executeDispatch(document, ".uno:InsertContents", "", 0, args4())
 
rem ----------------------------------------------------------------------
dim args5(0) as new com.sun.star.beans.PropertyValue
args5(0).Name = "ToPoint"
args5(0).Value = "$A$8"
 
dispatcher.executeDispatch(document, ".uno:GoToCell", "", 0, args5())
 
 
end sub

Open in new window

0
Comment
Question by:fastfind1
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
1 Comment
 
LVL 20

Accepted Solution

by:
ltlbearand3 earned 2000 total points
ID: 24092882
We could try and make the recorded macro work, but the code below should do the trick and is shorter.  Let me know how it works.  Just Paste it over top your current code.

-Bear

Sub PasteValues
	Dim oSheet
	Dim oRange
	Dim intCol
	Dim i
 
	' Get Access to Active Sheet
	oSheet = ThisComponent.CurrentController.getActiveSheet
	' Get the Current Range
	oRange = ThisComponent.getCurrentSelection
 
	' Find the Column Selected
	intCol = oRange.RangeAddress.StartColumn
 
	' Loop Through All Rows and Paste Value
	For i = oRange.RangeAddress.StartRow to oRange.RangeAddress.EndRow
		oOldCell = oSheet.getCellByPosition(intCol, i)
		oNewCell = oSheet.getCellByPosition(intCol, i)
		
		' If Numeric paste value, else paste string
		IF isnumeric(oNewCell.String) Then
			oOldCell.Value = oNewCell.Value
		Else
			oOldCell.String = oNewCell.String
		End If
	Next
	
End Sub

Open in new window

0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

An introduction to the wonderful sport of Scam Baiting.  Learn how to help fight scammers by beating them at their own game. This great pass time helps the world, while providing an endless source of entertainment. Enjoy!
Learn how to use the free Acronis True Image app to easily transfer data between iPhones and Android phones.
If you’ve ever visited a web page and noticed a cool font that you really liked the look of, but couldn’t figure out which font it was so that you could use it for your own work, then this video is for you! In this Micro Tutorial, you'll learn yo…
In this video, Percona Solutions Engineer Barrett Chambers discusses some of the basic syntax differences between MySQL and MongoDB. To learn more check out our webinar on MongoDB administration for MySQL DBA: https://www.percona.com/resources/we…
Suggested Courses

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question