rg20

Windows 10 / Office SaveAs

16 posts in this topic

#1 ·  Posted (edited)

Greetings all,

 

I have an app that runs fine in windows 7 but not windows 10.

issue : when entering the filename to save, it enters it into the saveAs dialog box, but Office still tries to save as "Diagram1" or "Presentation1"

 

$FileError = ""
        MonitorProcess2("VISIO")
        _DebugOut("Visio Done")

        MonitorProcess2("POWERPNT")

        _debugOut("Powerpoint Done")



        CloseSave($FileSavePathName, $SaveAsWindow)
        _DebugOut("Saved and closed Powerpoint")

        _VSO_DocumentSave($objVisioFile)
        while not _VSO_DocumentSaved($objVisioFile)
        WEnd
        _VSO_VisioClose($objVisioFile)
        _DebugOut("Saved and closed Visio")
    else
        _DebugOut("Filename Does not exist = "& $FilePathName)
    EndIf

the monitor process2 just makes sure the processes are complete before trying to save the files.

 

The closeSave function is below, but since I am opening the file with the proper name, this is not an issue

func CloseSave($SaveFile, $SaveAsWindow)
    _DebugOut("Save File ")
    _DebugOut($SaveFile)
    send("!{F4}")
    send ("!S")
    $title = WinGetTitle("[ACTIVE]")
    _DebugOut("WINDOW - current window is Powerpoint to enter filename " & $title)
    while not ($title = $SaveAsWindow)
        $title = WinGetTitle("[ACTIVE]")
    wend
    ControlSetText ($SaveAsWindow,"","[CLASS:Edit; INSTANCE:1]",$SaveFile)
    send ("!S")
        $title = WinGetTitle("[ACTIVE]")
    while not StringInStr($title,"Visio")
        $title = WinGetTitle("[ACTIVE]")
    wend
EndFunc

 

Edited by rg20

Share this post


Link to post
Share on other sites



#3 ·  Posted (edited)

You are correct, I was not calling that method as I had thought. (I have updated the original post to correct that)

 

I am using the controlsend.

 

The reason I use this is because Visio lauches a powerpoint app automatically, I seem to have an issue trying to get a handle on that application 

Edited by rg20

Share this post


Link to post
Share on other sites

#4 ·  Posted

Please have a look at my PowerPoint UDF -  it allows to connect to an already running PowerPoint instance/presentation.

 


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - 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

#5 ·  Posted

Thank you Water for your helpful advice,

 

I remvoed the closesave function and added the following

$oPPT =_PPT_Open()
      _PPT_PresentationAttach($oPPT,"partialtitle")
      _PPT_PresentationSaveAs($oPPT, "c:\a\test")
        _DebugOut("Saved and closed Powerpoint")

When I was done, I could not find a file in the directory C:\a.

I would expect to see test.ppt

 

Not sure if an object is being returned or I'm doing something wrong.

I modified the presentationAttach script to allow for partial title search as the number keeps increasing.

Func _PPT_PresentationAttach($sString, $sMode = Default)
    Local $oPresentation, $iCount = 0, $sCLSID_Presentation = "{91493444-5A91-11CF-8700-00AA0060263B}" ; Microsoft.Office.Interop.PowerPoint.PresentationClass
    If $sMode = Default Then $sMode = "FilePath"
    While True
        $oPresentation = ObjGet("", $sCLSID_Presentation, $iCount + 1)
        If @error Then Return SetError(1, @error, 0)
        Switch $sMode
            Case "filename"
                If $oPresentation.Name = $sString Then Return $oPresentation
            Case "filepath"
                If $oPresentation.FullName = $sString Then Return $oPresentation
            Case "title"
                If $oPresentation.Application.Caption = $sString Then Return $oPresentation
            Case "partialtitle"
                If StringInStr($oPresentation.Application.Caption,$sString) Then Return $oPresentation
            Case Else
                Return SetError(2, 0, 0)
        EndSwitch
        $iCount += 1
    WEnd
EndFunc   ;==>_PPT_PresentationAttach

 

Share this post


Link to post
Share on other sites

#6 ·  Posted

PresentationAttach and PresentationSaveAs require a presentation object. Hence it should be:

$oPPT =_PPT_Open()
$oPresentation = _PPT_PresentationAttach("text you are looking for in the title", "partialtitle")
_PPT_PresentationSaveAs($oPPT, $oPresentation, "c:\a\test")
_DebugOut("Saved and closed Powerpoint")

N.B: It is always a good idea to check @error after having calld a function.


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - 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

#7 ·  Posted

Awesome start, but missed a few things and still have one issue

 

If you open the PPT without saving it first, it seems like the environment can find it, but the attach can't attach to it

 

I created a slide deck named "hey you" in my documents folder then opened Powerpoint without saving it, so the default name was Presentation1 - Microsoft Powerpoint so my path looks like this

Row|Col 0|Col 1|Col 2
[0]||Presentation1|
[1]||hey you.pptx|C:\Users\....\Documents
 

then using this code, I put the Powerpoint.au3 in my local directory for now

 

#include "Powerpoint.au3"
#include "Visio.au3"
#include <misc.au3>
#include <File.au3>
#include <Debug.au3>

$oPPT =_PPT_Open()
$Presentations = _PPT_PresentationList($oPPT)
_ArrayDisplay($Presentations, "Sorted tree")
$oPresentation = _PPT_PresentationAttach("Presentation","title", True)
_PPT_SlideAdd($oPresentation)
_PPT_PresentationSaveAs($oPresentation, "C:\a\test" )

$oPresentation = _PPT_PresentationAttach("hey you","title", True)
_PPT_SlideAdd($oPresentation)

_PPT_PresentationSaveAs($oPresentation, "C:\a\test2" )

the attach with the "Presentation" does not get a second slide or saved

The "hey you" presentation does and is saved to the indicated pat as expected.

any thoughts?

Share this post


Link to post
Share on other sites

#8 ·  Posted

Seems to be a bug in the latest UDF version in function _PPT_SlideAdd.
Will need to rethink the function :( 
I think Alpha 3 doesn's have this bug - if needed I can post this version here or in the download Forum.


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - 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

#9 ·  Posted

On 6/16/2017 at 11:31 AM, water said:

 

Thanks for the update, I wasn't sure if I was going crazy.

 

I would love to have the new version for testing

Share this post


Link to post
Share on other sites

#10 ·  Posted

A newer/fixed Version (Alpha 6) isn't available yet. But I think Alpha 4 doesn's have this bug:

PowerPoint Alpha 4.zip


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - 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

#11 ·  Posted

I have tried this and experienced the same bug.  I think there is an issue with the attach when the file is not saved, IE no directory listed

 

Func _PPT_PresentationAttach($sString, $sMode = Default)
    Local $oPresentation, $iCount = 0, $sCLSID_Presentation = "{91493444-5A91-11CF-8700-00AA0060263B}" ; Microsoft.Office.Interop.PowerPoint.PresentationClass
    If $sMode = Default Then $sMode = "FilePath"
    While True
        $oPresentation = ObjGet("", $sCLSID_Presentation, $iCount + 1)
        If @error Then Return SetError(1, @error, 0)  <-------------------This is the line kicking back the error message
        Switch $sMode
            Case "filename"
                If $oPresentation.Name = $sString Then Return $oPresentation
            Case "filepath"
                If $oPresentation.FullName = $sString Then Return $oPresentation
            Case "title"
                If $oPresentation.Application.Caption = $sString Then Return $oPresentation
            Case Else
                Return SetError(2, 0, 0)
        EndSwitch
        $iCount += 1
    WEnd
EndFunc   ;==>_PPT_PresentationAttach

 

I get this 

Share this post


Link to post
Share on other sites

#12 ·  Posted

Use

MsgBox(0, "Presentation Name", $oPresentation.Name)
MsgBox(0, "Presentation FullName", $oPresentation.FullName)
MsgBox(0, "Presentation Caption", $oPresentation.Application.Caption)

to make sure you use the correct values for _PPT_PresentationAttach.
The line you marked is called when none of the presentations fits the query string.


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - 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

#13 ·  Posted (edited)

use your PPT script and try the below script code

but before you run it, just open PowerPoint, you should get a new presentation named "Presentation 1 - Microsoft Powerpoint" but don't save it to a directory

you can even substitue the full presentation name.

 

Once it's saved, it will then recognize the file.

 

#include "Powerpoint.au3"
#include "Visio.au3"
#include <misc.au3>
#include <File.au3>
#include <Debug.au3>

$oPPT =_PPT_Open()
$Presentations = _PPT_PresentationList($oPPT)
_ArrayDisplay($Presentations, "Sorted tree")
$oPresentation = _PPT_PresentationAttach("Presentation","title", True)

If @error Then
    MsgBox($MB_SYSTEMMODAL, "PowerPoint UDF: _PPT_PresentationAttach Example", "'" & $oPresentation & "'." & @CRLF & "@error = " & @error & ", @extended = " & @extended)
    _PPT_Close($oPPT)
    Exit
EndIf

adding your messages into the PPT includes shows

>"C:\Program Files (x86)\AutoIt3\SciTE\..\autoit3.exe" /ErrorStdOut "\\abbvienet.com\data\R&D\R478\Excel Clinical Schedule Scripts\ppttest.au3"    
"\\abbvienet.com\data\R&D\R478\Excel Clinical Schedule Scripts\Powerpoint.au3" (144) : ==> Variable must be of type "Object".:
ConsoleWrite("Presentation Name" & $oPresentation.Name & @CRLF)
ConsoleWrite("Presentation Name" & $oPresentation^ ERROR
>Exit code: 1    Time: 0.6098

 

Edited by rg20

Share this post


Link to post
Share on other sites

#14 ·  Posted

My test crashes when i try to attach to an unsaved presentation.
As soon as I save the presentation the script works without Problem.
Seems you can't connect to a presentation that hasn't been saved yet. This is true for Office 2010. My System will be upgraded today to Office 2016.

Will check if it works for Office 2016 and Word.


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - 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

#15 ·  Posted

I tested with Excel and the result is the same: You can't connect to an unsaved workbook.

I think the workaround is to create the new presentation by using _PPT_PresentationNew.


My UDFs and Tutorials:

Spoiler

UDFs:
Active Directory (NEW 2017-04-18 - Version 1.4.8.0) - Download - General Help & Support - Example Scripts - Wiki
OutlookEX (NEW 2017-02-27 - Version 1.3.1.0) - 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

#16 ·  Posted

On 6/20/2017 at 1:58 AM, water said:

I tested with Excel and the result is the same: You can't connect to an unsaved workbook.

I think the workaround is to create the new presentation by using _PPT_PresentationNew.

I wish I had that option, I might have to do a keystroke temporary save, then update save and delete the temp

 

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

  • Similar Content

    • BBs19
      By BBs19
      Features:
      Create modern looking borderless and resizable GUIs with control buttons (Close,Maximize/Restore,Minimize, Fullscreen, Menu) True borderless, resizeable GUI with full support for aerosnap etc. Many color schemes/themes included. See MetroThemes.au3 for more details. 3 type of Windows 8/10 style buttons. Modern checkboxes, radios, toggles and progressbar. All buttons, checkboxes etc. have hover effects! Windows 10 style modern MsgBox. Windows 10/Android style menu that slides in from left. Windows 10 style right click menu  
      Credits: @UEZ, for the function to create buttons with text using GDIPlus. @binhnx for his SSCtrlHover UDF
       
      Changelog:
      Download UDF with example:
       
       
    • keelaji
      By keelaji
      Hello,
      first of all i searched in the forum but i didn't found any solution to my problem.
      I am using windows 10.
      I made a script that is supposed to change the title to the active window, resize it to the smallest size possible (should be around 800 x 600) and move to (0, 0).
      I can change the title but i fail to do the other 2 tasks.
      i use wingettitle [active] copied from the F1 help tool (and this works), i i put the title in a variable and than i use
      winsettitle ($variable, "one") (this works too)
      winmove ("one", 0, 0, 800, 600) (doesn't do anything)
      i also tried
      local $x = winget ( "one")
      msgbox (0, "", $x) (i get a completely white box so i suppose winget can't have any data about my window ??)
      any suggestion ?
    • spuuunit
      By spuuunit
      I have a script that autostart with Windows, and sometimes some of my code is skipped. My script takes long pauses, so it's not that the script "goes too fast". This is my script for now:
      TraySetIcon("C:\Portables\AutoIt\_\icon.ico") AutoItSetOption("WinTitleMatchMode", 2) Run("C:\Portables\Key Manager\keymanager.exe") WinActivate("ATNSOFT Key Manager v") WinWaitActive("ATNSOFT Key Manager v") WinMove("ATNSOFT Key Manager v", "", 650, 200, 600, 800) Sleep(500) $pos = MouseGetPos() MouseClick("left", 1220, 210, 1, 100) MouseMove($pos[0], $pos[1], 100) Run("C:\Portables\foobar2000\foobar2000.exe") $version = 298 For $i = 0 To 99 Step 1 $path = "C:\Users\spunit\AppData\Local\Discord\app-0.0." & $version + $i & "\Discord.exe" If FileExists($path) Then Run($path) ExitLoop EndIf Next Run("C:\Portables\Firefox\FirefoxPortable.exe") Sleep(10000) WinMove("- Mozilla Firefox", "", 205, 0, 1214, 1047) Sleep(100) MouseClick("left", 1300, 15, 1, 10) Sleep(100) MouseClick("left", 1130, 275, 1, 10) Sleep(100) MouseClick("left", 930, 105, 1, 10) Sleep(100) Send("#{m}") Sometimes it skips to click and move mouse right after Key Manager starts. Almost always it skips everything after the last run.

      This type of script were never an issue with Windows 7... Any thoughts?
    • VIP
      By VIP
      I can not do anything with any user in the "Local Users Group"
      I tried from my account but I could not change my password (ie set new password)!
      But I was able to activate the Administrator account and I logged into the Administrator account and still could not do anything with my account! But I can set the password and disable the Administrator account from my account or Administrator.
      Any ideas? (Ignore the click on the Sign-in option in the Change Accout settings.)
       

    • dreivilo47
      By dreivilo47
      When I want to test Example 1 of Function _IECreate (AutoIt Help File), I see that function _IECreate doesn't work in Windows 10.
      Syntax Check (Ctrl+F5) gives no errors.
       
      Example 1:
      ; Create a browser window and navigate to a website #include <IE.au3> Local $oIE = _IECreate("www.autoitscript.com")  
      The error I receive with F5 (Tools, Go) in SciTE: