danmcg Posted November 19, 2020 Posted November 19, 2020 (edited) so would like to move my autoit script inside the VBE but having an issue with constants. how can i add the #include found in my autoitscript and add that to my excel procedure Sub LoadAutoIt() On Error Resume Next 'early binding Dim autoit As AutoItX3 Set autoit = New AutoItX3 'how can i set the includes so that my program finds the constants? Call autoit.Run("C:\Program Files (x86)\Office RibbonX Editor\OfficeRibbonXEditor.exe") Call autoit.WinWait("Office RibbonX Editor") Call autoit.WinSetState("Office RibbonX Editor", "") 'Sleep (10000) Call autoit.Send("^o") Call autoit.Send("C:\Users\USERNAME\Documents\Excel\RibbonTester.xlsm") End Sub and here is where it messes up... Call autoit.WinSetState("Office RibbonX Editor", "", @SW_MAXIMIZE) and here is my au3 script (that is working perfectly) #include <AutoItConstants.au3> #include <MsgBoxConstants.au3> run("C:\Program Files (x86)\Office RibbonX Editor\OfficeRibbonXEditor.exe") WinSetState("Office RibbonX Editor", "", @SW_MAXIMIZE) sleep(10000) send("^o") send("C:\Users\purchasing\Documents\Excel\RibbonTester.xlsm") sleep(5000) send("{ENTER}") send("^a") send("^v") sleep(5000) MouseClick($MOUSE_CLICK_LEFT, 360, 60, 2) if WinExists("XML is Valid") then ;MsgBox($MB_APPLMODAL,"XML is Valid","Your Ribbon Code is Valid",5) send("{ENTER}") send("^s") send("^w") winclose("Office RibbonX Editor") run("C:\Program Files (x86)\Microsoft Office\root\Office16\excel.exe C:\Users\purchasing\Documents\Excel\RibbonTester.xlsm") Else MsgBox($MB_APPLMODAL,"Error","There are error(s) with the xml code",10) winclose("Office RibbonX Editor") EndIf Edited November 19, 2020 by danmcg adding extra code to describe my issues
Danp2 Posted November 19, 2020 Posted November 19, 2020 20 minutes ago, danmcg said: @SW_MAXIMIZE Did you try like this? Call autoit.WinSetState("Office RibbonX Editor", "", autoit.SW_MAXIMIZE) Latest Webdriver UDF Release Webdriver Wiki FAQs
JockoDundee Posted November 19, 2020 Posted November 19, 2020 16 minutes ago, Danp2 said: Did you try like this? or failing that, like this? Call autoit.WinSetState("Office RibbonX Editor", "", 1) Code hard, but don’t hard code...
mLipok Posted November 19, 2020 Posted November 19, 2020 as to your topic title: Quote Found out how to add reference to AutoItX3.dll, now how can i add the #include in the excel procedure You could not add #include with AutoItX. You can only use enlisted function in this part of AutoItX.chm Signature beginning:* Please remember: "AutoIt"..... * Wondering who uses AutoIt and what it can be used for ? * Forum Rules ** ADO.au3 UDF * POP3.au3 UDF * XML.au3 UDF * IE on Windows 11 * How to ask ChatGPT for AutoIt Code * for other useful stuff click the following button: Spoiler Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST API * ErrorLog.au3 UDF - A logging Library * Include Dependency Tree (Tool for analyzing script relations) * Show_Macro_Values.au3 * My contribution to others projects or UDF based on others projects: * _sql.au3 UDF * POP3.au3 UDF * RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF * SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF * SciTE - Lexer for console pane * Useful links: * Forum Rules * Forum etiquette * Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * Wiki: * Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * OpenOffice/LibreOffice/XLS Related: WriterDemo.au3 * XLS/MDB from scratch with ADOX IE Related: * How to use IE.au3 UDF with AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskScheduler * IE Embedded Control Versioning (use IE9+ and HTML5 in a GUI) * PDF Related: * How to get reference to PDF object embeded in IE * IE on Windows 11 * I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions * EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *I also encourage you to check awesome @trancexx code: * Create COM objects from modules without any demand on user to register anything. * Another COM object registering stuff * OnHungApp handler * Avoid "AutoIt Error" message box in unknown errors * HTML editor * winhttp.au3 related : * https://www.autoitscript.com/forum/topic/206771-winhttpau3-download-problem-youre-speaking-plain-http-to-an-ssl-enabled-server-port/ "Homo sum; humani nil a me alienum puto" - Publius Terentius Afer"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming" , be and \\//_. Anticipating Errors : "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty." Signature last update: 2023-04-24
danmcg Posted November 19, 2020 Author Posted November 19, 2020 thanks dan and jocko. now how do i code for this? $MOUSE_CLICK_LEFT. tried autoit.$ but nothing enumerates. how can i fix this?
Danp2 Posted November 19, 2020 Posted November 19, 2020 Then look up the constant value in AutoitConstants.au3 and use that instead. Latest Webdriver UDF Release Webdriver Wiki FAQs
JockoDundee Posted November 19, 2020 Posted November 19, 2020 19 minutes ago, danmcg said: thanks dan and jocko. now how do i code for this? $MOUSE_CLICK_LEFT. tried autoit.$ but nothing enumerates. how can i fix this? The button to click: $MOUSE_CLICK_LEFT ("left") $MOUSE_CLICK_RIGHT ("right") $MOUSE_CLICK_MIDDLE ("middle") $MOUSE_CLICK_MAIN ("main") $MOUSE_CLICK_MENU ("menu") $MOUSE_CLICK_PRIMARY ("primary") $MOUSE_CLICK_SECONDARY ("secondary") so try “left” Code hard, but don’t hard code...
danmcg Posted November 19, 2020 Author Posted November 19, 2020 thanks again, both of you. got it figured out.
Recommended Posts
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 accountSign in
Already have an account? Sign in here.
Sign In Now