Excel automation export: Large Data Amount in one cell

StLiStLi Member Posts: 83
Hi!

I wrote an Excel Export with automations (Excelbuffer doesn't fit my needs) on a 4.0 SP3 Database

The Problem: i have one cell where i want to export the content of several records into one cell.

Because of the 1024 Char limit. I tried to do it like this (simplyfied):
// xlWks is a Worksheet automation
// nextline is the current line I'm on
// N is just the column i happen to want to fill the data into
if t1.findset then
  repeat
    xlWks.Range('N' + FORMAT(nextLine)).Value(
        FORMAT(xlWks.Range('N' + FORMAT(nextLine)).Value) + ' ' + t1.Text);
  until t1.next = 0;

For debugging i already filled the t1.text with the following data (one record per row)
a1111111111111111111111111111111111111111111111111111111111111111111111111111111
b2222222222222222222222222222222222222222222222222222222222222222222222222222222
c3333333333333333333333333333333333333333333333333333333333333333333333333333333
d4444444444444444444444444444444444444444444444444444444444444444444444444444444
e5555555555555555555555555555555555555555555555555555555555555555555555555555555
f6666666666666666666666666666666666666666666666666666666666666666666666666666666
g7777777777777777777777777777777777777777777777777777777777777777777777777777777
h8888888888888888888888888888888888888888888888888888888888888888888888888888888
i9999999999999999999999999999999999999999999999999999999999999999999999999999999
j0000000000000000000000000000000000000000000000000000000000000000000000000000000
kAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
lBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB
mCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC

... and i expected to the see something simular in my Excel Cell... unfortunatly i got this: (I'm really confused about this result.)
 a1111111111111111111111111111111111111111111111111111111111111111111111111111111 b2222222222222222222222222222222222222222222222222222222222222222222222222222222 c3333333333333333333333333333333333333333333333333333333333333333333333333333333 d44444444444   4mCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCmCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCm

I already added a sleep(1000) command to the loop and what i saw looked like excel starts to overwrite and/or copy the last parts of the already entered data after the content reaches a certain size.... can anyone help me to get my expected result?

(actually i want to have line feeds between the records, but that's a different problem I'll address later.) The linefeed thing was easy: i just added a Char Variable set it to 10 and added it where i wanted to have it.

Comments

  • geordiegeordie Member Posts: 655
    Which version of Excel are you using?
  • StLiStLi Member Posts: 83
    the Object library is 12.0 (2007)
    To get you more detailed data, i started stepping the loop and here is what i got after each iteration: (i replaced the space with a pipe because i got multiple spaces next to each other at one point)
    (lenght)
    (content)
    1st:
    81
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111
    
    162
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222
    
    243
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333
    
    324
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d4444444444444444444444444444444444444444444444444444444444444444444444444444444
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4e5555555555555555555555555555555555555555555555555555555555555555555555555555555e5555555555555555555555555555555555555555555555555555555555555555555555555555555e
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4f6666666666666666666666666666666666666666666666666666666666666666666666666666666f6666666666666666666666666666666666666666666666666666666666666666666666666666666f
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4g7777777777777777777777777777777777777777777777777777777777777777777777777777777g7777777777777777777777777777777777777777777777777777777777777777777777777777777g
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4h8888888888888888888888888888888888888888888888888888888888888888888888888888888h8888888888888888888888888888888888888888888888888888888888888888888888888888888h
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4i9999999999999999999999999999999999999999999999999999999999999999999999999999999i9999999999999999999999999999999999999999999999999999999999999999999999999999999i
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4j0000000000000000000000000000000000000000000000000000000000000000000000000000000j0000000000000000000000000000000000000000000000000000000000000000000000000000000j
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4kAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAkAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAk
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|b2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4lBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBlBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBl
    
    421
    |a1111111111111111111111111111111111111111111111111111111111111111111111111111111|C2222222222222222222222222222222222222222222222222222222222222222222222222222222|c3333333333333333333333333333333333333333333333333333333333333333333333333333333|d44444444444|||4mCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCmCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCm
    

    apparently the length stays the same after it reaches it's peak of 421. somehow after the 256th char, most of the content gets cut off. vor some reason the next char i add gets repeated 3 times and then comes one char from the previously cut of sequence (that 4) and then the newly added string get added... two times ... plus the first char from the 3rd time.

    edit: sorry for messing up the forum layout.
  • StLiStLi Member Posts: 83
    Ok, I'm on round two here:

    I've discovered this Automation: 'Navision Attain Hash 1.0'.BSTRConverter

    Now, I write the Data i want to export into the BStr-automation and i can assign it to the cell using
    xlWks.Range('N' + FORMAT(nextLine)).Value := BStrConv.BSTR;
    

    however i get an overflow error if the lenght of BStrConv exceeds 1024 chars. I've currently solved it by filling the portions into an array and assigning the content to different Cells but I'm still not happy with that solution. In case someone has solved this issue, i'd be glad to hear about it... P.s. I can't send the whole automation to the value (like they did it on the same issue wird the mail body on other threads in this forum.) i have to use the BSTR-Property.

    best regards
Sign In or Register to comment.