Jump to content
Sign in to follow this  
jhtromb

Excel - Copy empty string brings up length "2"

Recommended Posts

jhtromb

Hello,

I have a little problem working with AutoIT and Excel:

I need to copy some values from an Excel List and I want the script to loop until it copies an empty cell.

; copy value in cell
Send("{CTRLDOWN}")
Send("{c}")
Send("{CTRLUP}")

$value = ClipGet()

; go down one row
Send("{DOWN}")

; loop through list until reaching an empty cell
while $value <> ""

     ; work with value
     ; ......

    ; copy value in cell
    Send("{CTRLDOWN}")
    Send("{c}")
    Send("{CTRLUP}")
    $value = ClipGet()
    ; go down one row
    Send("{DOWN}")

WEnd

This script does not work, because it does not recognize the content of an empty cell as "", so the comparison with <> does not stop the loop.

I tried to find out the problem: if I make a message box with StringLen($value) it shows me that the length of the empty cell is "2". When I try StringLen("") it gives me the value 0.

Anyone any idea why the length of the empty string is 2 and not 0?

Thank you very much!

Share this post


Link to post
Share on other sites
water

Why don't you use Excel UDF which comes with AutoIt? Use _ExcelReadCell and _ExcelWriteCell to copy a cell.


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2018-06-01 - Version 1.4.9.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (2018-01-27 - Version 1.3.3.1) - Download - General Help & Support - Example Scripts - Wiki
ExcelChart (2015-04-01 - Version 0.4.0.0) - Download - General Help & Support - Example Scripts
Excel - Example Scripts - Wiki
Word - Wiki
PowerPoint (2015-06-06 - Version 0.0.5.0) - Download - General Help & Support

Tutorials:
ADO - Wiki

 

Share this post


Link to post
Share on other sites
Melba23

jheinze,

At a guess it is a @CRLF character (or 2 characters to be absolutely correct). :doh:

Try this and see if it works: :bye:

while $value <> @CRLF

But why not use the Excel UDF to do this? :oops:

M23


Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind._______My UDFs:

Spoiler

ArrayMultiColSort ---- Sort arrays on multiple columns
ChooseFileFolder ---- Single and multiple selections from specified path treeview listing
Date_Time_Convert -- Easily convert date/time formats, including the language used
ExtMsgBox --------- A highly customisable replacement for MsgBox
GUIExtender -------- Extend and retract multiple sections within a GUI
GUIFrame ---------- Subdivide GUIs into many adjustable frames
GUIListViewEx ------- Insert, delete, move, drag, sort, edit and colour ListView items
GUITreeViewEx ------ Check/clear parent and child checkboxes in a TreeView
Marquee ----------- Scrolling tickertape GUIs
NoFocusLines ------- Remove the dotted focus lines from buttons, sliders, radios and checkboxes
Notify ------------- Small notifications on the edge of the display
Scrollbars ----------Automatically sized scrollbars with a single command
StringSize ---------- Automatically size controls to fit text
Toast -------------- Small GUIs which pop out of the notification area

 

Share this post


Link to post
Share on other sites
jhtromb

Thank you very much, both! :oops:

Both ideas work well. I did not think wide enough to use Excel UDF as I'm an AutoIT newbie. Thank you!

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

×