Solved

Excel, add row, shift all values down - Please Help!!!

Posted on 2007-11-15
4
746 Views
Last Modified: 2008-02-01
I am taking a .txt file delimiting it and exporting to excel. I need to add a row (column names) from a different spreadsheet to where my exported spreadsheet exists.  
thanks in advance
strExcelPath = "C:\myfiles\header.xls"
 
Const ForReading = 1
Const ForWriting = 2
 
'Added to save changes without being prompted by Excel
Const xlSaveChanges = 1
 
Set objFSO = CreateObject("Scripting.FileSystemObject")
 
Set objFile = objFSO.OpenTextFile("C:\myfiles\test.txt", ForReading)
strContents = objFile.ReadAll
objFile.Close
 
strContents = Replace(strContents, "|", vbTab)
 
Set objFile = objFSO.OpenTextFile("C:\myfiles\test.txt", ForWriting)
objFile.Write strContents
objFile.Close
 
Set objExcel = CreateObject("Excel.Application")
'Add row here???
'Shift all other values down
Set objWorkbook = objExcel.Workbooks.Open("C:\myfiles\test.txt")
objExcel.ActiveWorkbook.cells.addrow("1,1")
objExcel.ActiveWorkbook.SaveAs strExcelPath
objExcel.ActiveWorkbook.Close xlSaveChanges
objExcel.Application.Quit
WScript.Echo "The Upload is Complete"

Open in new window

0
Comment
Question by:gabulish
[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
  • 2
4 Comments
 
LVL 81

Expert Comment

by:byundt
ID: 20300506
Instead of:
objExcel.ActiveWorkbook.cells.addrow("1,1")


Try:
objExcel.ActiveWorkbook.ActiveWorksheet.Rows(1).Insert

0
 
LVL 49

Accepted Solution

by:
DanRollins earned 150 total points
ID: 20300567
One option would be to insert the line when you write the file (rather than after importing into Excel).  That might look something like this:
Set objFile = objFSO.OpenTextFile("C:\myfiles\test.txt", ForReading)
strContents = objFile.ReadAll
objFile.Close
 
strContents = Replace(strContents, "|", vbTab)
 
Set objFile = objFSO.OpenTextFile("C:\myfiles\test.txt", ForWriting)
 
' REM added this line --------------------------
objFile.Write "clm1" +vbTab+ "clm2" +vbTab+ "clm3" +vbCr
 
objFile.Write strContents
objFile.Close

Open in new window

0
 

Author Comment

by:gabulish
ID: 20300680
DanRollins,

I like your approach. Could I open another WorkBook and grab a row from a Worksheet and paste it into the original Workbook, Worksheet?

thanks much,

gabulish
0
 
LVL 49

Expert Comment

by:DanRollins
ID: 20301551
I suppose so.  You would need to access functions of your objExcel object and extract the desired text from the specidied cells.  I have little experience with the Excel object model.
0

Featured Post

[Webinar] How Hackers Steal Your Credentials

Do You Know How Hackers Steal Your Credentials? Join us and Skyport Systems to learn how hackers steal your credentials and why Active Directory must be secure to stop them. Thursday, July 13, 2017 10:00 A.M. PDT

Question has a verified solution.

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

This script will sweep a range of IP addresses (class c only, 255.255.255.0) and report to a log the version of office installed. What it does: 1.)      Creates log file in the directory the script is run from (if it doesn't already exist) 2.)      Sweep…
Not long ago I saw a question in the VB Script forum that I thought would not take much time. You can read that question (Question ID  (http://www.experts-exchange.com/Programming/Languages/Visual_Basic/VB_Script/Q_28455246.html)28455246) Here (http…
There are cases when e.g. an IT administrator wants to have full access and view into selected mailboxes on Exchange server, directly from his own email account in Outlook or Outlook Web Access. This proves useful when for example administrator want…
Do you want to know how to make a graph with Microsoft Access? First, create a query with the data for the chart. Then make a blank form and add a chart control. This video also shows how to change what data is displayed on the graph as well as form…

717 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