Excel pdf:ksi makro

Poka_33

Kunde on pelastanut ennenkin pahoista pulmista jospa näin kävisi uudelleen...

Eli ongelma on seuraavanlainen:

Minulla on välilehti excelissä avoinna kutsutaan sitä vaikka "raportti"lehdeksi.

Nyt haluaisin makron joka automaattisesti menisi "tulosta" asetukseen, valitsisi sieltä tulostimeksi "Pdf-exchange 4.0" ja tallentaisi sen polkuun c:\liitteet\raportti.pdf

Tämän jälkeen palauttaisi tuon "tulosta-asetuksen" oletustulostimeksi mikä alunperin jo siinä oli.

3 h olen koettanut leikkiä mutta ei tule valmista ja pääkipu senkun kasvaa. Ongelmaksi muodostuu tuo tulostimen valinta ja palautus.

11

1435

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • jakari4900

      Olisiko tästä apua, vastaava tehty pdf-creatorilla. Tässä ei tarvitse vaihdella oletustulostinta. Tallentaa s

      Option Explicit
      Sub PrintPDF_Early()

      'Option Explicit
      'Author : Ken Puls (www.excelguru.ca)
      'Macro Purpose: Print to PDF file using PDFCreator
      ' (Download from http://sourceforge.net/projects/pdfcreator/)
      ' Designed for early bind, set reference to PDFCreator

      Dim pdfjob As PDFCreator.clsPDFCreator
      Dim sPDFName As String
      Dim sPDFPath As String
      Dim Nimi As String


      Nimi = Range("A7") & Range("H3") & Range("I3")

      '/// Change the output file name here! ///
      sPDFName = Nimi

      sPDFPath = ActiveWorkbook.Path & Application.PathSeparator
      'vaihda ylläoleva polku sopivaksi

      'Check if worksheet is empty and exit if so
      If IsEmpty(ActiveSheet.UsedRange) Then Exit Sub

      Set pdfjob = New PDFCreator.clsPDFCreator

      With pdfjob
      If .cStart("/NoProcessingAtStartup") = False Then
      MsgBox "Can't initialize PDFCreator.", vbCritical _
      vbOKOnly, "PrtPDFCreator"
      Exit Sub
      End If
      .cOption("UseAutosave") = 1
      .cOption("UseAutosaveDirectory") = 1
      .cOption("AutosaveDirectory") = sPDFPath
      .cOption("AutosaveFilename") = sPDFName
      .cOption("AutosaveFormat") = 0 ' 0 = PDF
      .cClearCache
      End With

      'Print the document to PDF
      ActiveSheet.PrintOut copies:=1, ActivePrinter:="PDFCreator"

      'Wait until the print job has entered the print queue
      Do Until pdfjob.cCountOfPrintjobs = 1
      DoEvents
      Loop
      pdfjob.cPrinterStop = False

      'Wait until PDF creator is finished then release the objects
      Do Until pdfjob.cCountOfPrintjobs = 0
      DoEvents
      Loop
      pdfjob.cClose
      Set pdfjob = Nothing
      End Sub

      • Poka_33

        Kiitos vaan Jakari mutta pyyhkii yli ja kovaa tuo koodi että osaisin edes sitä soveltaaa =(


    • Poka_33

      Kävikin hyvin. En tarvinnut kuin omaa apuani ja opin prosessissa jopa jotain. Ei vienyt kuin 5 h ja unettoman yön miettiessä.

      Tällaisen kehitin ja toimii riittävän hyvin =)

      Sub liite()

      Dim STDprinter As String
      STDprinter = Application.ActivePrinter
      Application.ActivePrinter = "PDF-XChange 4.0 porttiin Ne00:"
      ' vaihtaa tulostimen
      ActiveSheet.PrintOut
      'printtaa välilehden
      Application.ActivePrinter = STDprinter
      ' Vaihtaa takaisin oletustulostimeksi
      End Sub

    • Poka_33

      Hmmm...Vielä olisi sen verran muokattavaa että saisin tuon pdf tallentumaan tiettyyn paikkaan; esim c:\liitetiedostot


      Anyone ?

      • jakari4900

        Mihin se nykyisin lykkää pdf:n? Jos innostusta riittää voisit kokeilla pientä muutosta, eli pari riviä lisää.


        Sub liite()

        Dim STDprinter As String

        Dim STDprinterPath As String
        'onnistuisiko tällä lisäyksellä

        STDprinter = Application.ActivePrinter
        sPDFPath = C:\liitetiedostot
        'ja tällä polulla, tosin kansio pitänee olla valmiina

        Application.ActivePrinter = "PDF-XChange 4.0 porttiin Ne00:"
        ' vaihtaa tulostimen
        ActiveSheet.PrintOut
        'printtaa välilehden
        Application.ActivePrinter = STDprinter
        ' Vaihtaa takaisin oletustulostimeksi
        End Sub


    • Poka_33

      Ei toimi...Alkaa herjaamaan tuota
      sPDFPath = C:\liitetiedostot

      hmmmm....

    • Poka_33

      En saa toimimaan..Joko Kunde on palannut lomalta neuvomaan kuolevaisia ?

      • himassahan sitä ollaan taas!

        tää koodin pätkä pitäisi toimia, eli vaihtaa oletustulostimen PDF-XChangeksi ja tulostaa tiedoston ja sitten palauttaa oletustulostimen takaisin

        Ei ole koneella tota PDF-XChange tulostinohjelmaa, mutta eiköhän sen omimaisuuksista voi suoraan määritellä tarvittavat polut ja oletusnimet....

        eli menusta FILE/PRINT ja avautuvasta valikosta valitset ton PDF-XChange tulostimen ja klikkaa vieressä olevaa PROPERTIES nappia ja sitten vaan kattelet, jospa jossain olisi tallennusasetukset ja rukkaat ne kohilleen...
        polku= C:\liitteet
        nimi=raportti

        moduuliin...

        Dim Oletustulostin As String
        Oletustulostin = Application.ActivePrinter
        Application.ActivePrinter = "PDF-XChange 4.0 on Ne05:"
        ActiveSheet.PrintOut
        Application.ActivePrinter = Oletustulostin
        End Sub


        Keep EXCELing
        @Kunde


    • Poka_33

      Ei toimi haluamallani tavalla noilla neuvoilla. Kyseessä on tiedosto jossa on monta välilehteä jotka jokainen sisältää tuon "liitetiedosto" napin. Nyt jos yhdessä teen nuo mainitsemasi asetukset, se sama kertaantuu jokaisessa välilehdessä, esim nimi: Raportti . jonku välilehden nimi voi olla esim "työtunnit".

      Olisiko tuota koodia mahdollista tehdä niin että se hakisi liitetiedoston nimen joltain solulta esim A1 ja nimeäisi raportin aina sen mukaan?

      Jostain syystä tuo tallennuspaikka vaikka sen asettaa "ominaisuudet" paikasta johonkin polkuun viittamaan ei toimi =(

    • niinpä...
      et kertonut aluksi, että haluat tulostaa useampia välilehtiä eri nimillä ja hakoteillä olin taas...
      Ei taida onnistua tuo, koska printteri näköjään kuitenkin käyttää tallenna lomaketta tulostaessaan taulukkoa ja kokeilin syöttää siihen sitten tietoja eri tavoilla (osaan kyllä ton) ja virhettä pukkaa aina ja ohjeita ei loe mikä mattää :-(
      Netistä löysin ilmaisen toimivan version sun tapaukseen( ei tartte paljoa fiksata Print Multiple Worksheets to Multiple PDF Files koodia) ja tuntui toimivan ihan jees...

      koodi
      http://www.excelguru.ca/node/21#MultiMulti

      printteri
      http://sourceforge.net/projects/pdfcreator/

      Keep EXCELing
      @Kunde

    • Poka_33

      Ei oikein onnistu kun näihin "firman" koneisiin ei pysty lataamaan mitään ohjelmia =(

      Noh täytynee tyytyä tuohon alkuoperäiseen koodiin. Kiitos kuitenkin !

    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Muistatko kaivattusi

      Syntymäpäivän? Päivämäärä riittää. 🌹
      Ikävä
      126
      1740
    2. 105
      1215
    3. Postimerkki kirjeeseen ja kortiin maksaa jo 3 euroa!

      https://yle.fi/a/74-20229241 Kyllä tämä on järjetön hinta, Posti tuhoaa itsensä tällä hinnalla, täytyyhän Postin "Herro
      Maailman menoa
      138
      1091
    4. Mulla on ikävä

      sua nainen ja niitä katseita ❤️ Lupaatko, että katseemme kohtaa taas?
      Ikävä
      49
      999
    5. Miten pääsee ujon naisen pään sisään?

      Siis tosi tosi tosi ujon...
      Ikävä
      130
      900
    6. Keitä oli kunnanjohtajan erottajat?

      Kouluja ei ole varaa ylläpitää mutta johtajasopimukseen palaa 100000 euroa ja uuden johtajan hakuprosessi maksaa kymmeni
      Ilmajoki
      52
      887
    7. Atte Harjanne usuttaa eläkeläisvihaan

      Karmeeta kuultavaa aamun uutislähetyksessä, kun Atte Harjanne, tunnettu eläkeläisvihaaja, suitsii sukupolvien välistä v
      Maailman menoa
      240
      868
    8. Helsingin Mäntymäki muuttui Kultajuhlan jälkeen kaatopaikaksi.

      Mitä se kertoo jääkiokosta ja lätkäfaneista? Saikkua huomenna huusi fani yöllä?
      Maailman menoa
      73
      757
    9. Pridekulkue kiellettävä?

      Näin täällä suoraan vaaditaan. Perusteina mitä mielikuvituksellisimmat tarinat. No, miksi ihmeessä kukaan ei ole samalla
      Luterilaisuus
      178
      739
    10. Mä oon tyytyväinen, että ei ole enää tunteita.

      Samalla tajusin, että sun kohdalla tykkäsin enemmän niistä tunteista kuin sinusta persoonana. Halusin väkisin nähdä sinu
      Ikävä
      55
      729
    Aihe