Määrätyn solualueen tulostaminen pdf-sivuna

Kalenterikalle

Otin käyttöön vanhan, mutta edelleen toimivan Excel-lomatuurauskalenterin, jolle olisi kysyntää.

Tässä alkutiedot kalenterista:
Koko vuoden (52 vk) kattava solualue on iso, eli B2-NE40, mutta kerralla ruudulla näkyvä alue on 31 saraketta ja 40 riviä, josta ensimmäiset 4 saraketta A-D on lukittu paikalleen, ja sarakkeet E-NE liukuu vaakasuunnassa ns. "mattona" lukitun alueen alle niin, että vain työstettävä 28 sarakkeen kenttä (4 vk) kerrallaan näkyy.
A-sarake ja 1. rivi ovat marginaaleja, eivätkä näyttele mitään muuta roolia.

Varsinainen kysymykseni kuuluukin, miten saan tulostettua vaakasuunnassa yhdelle pdf:lle, kun tulostettava alue olisi AINA sama, eli alkaen aina solusta B2 31 saraketta ja B2 39 riviä.
Onko tuossa nyt sitten kyseessä absoluuttisen vai suhteellisen alueen tulostamisesta, kun osa alueesta pysyy vakiona ja osa alueesta vaihtuu?

Jos tuon ajatukseni saisi VB-koodilla, niin osaisin hieman jopa hahmottaa miten se tapahtuu.

13

255

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Kalenterikalle

      Korjaus,
      Varsinainen kysymykseni kuuluukin, miten saan tulostettua vaakasuunnassa yhdelle pdf:lle, kun tulostettava alue olisi AINA sama, eli alkaen aina solusta B2 30 saraketta ja B2 39 riviä.

    • ctrl_c__ctrl_v

      Tee uusi tiedosto noilla tiedoilla ja tallenna se pdf.

    • Kalenterikalle

      Jäi mainitsematta, että jos tuon saisi siis VB:llä toteutettua, niin sille voisi luoda napin jolla kätevästi tulostaisi tuon pdf:n. Toki tiedän ja osaankin tehdä tuon ns. perinteisellä copy-pastettamallakin, mutta siinä pitää edelleen säätää ja viritellä muotoilut ym.. eli ei kätevä VB:llä painonapilla tehtyyn verrattuna. Kiitos kuitenkin vinkistä, mutta ei tällä kertaa houkutteleva vaihtoehto.

      • Tämmöinen

        Valitse tulostimeksi käyttämäsi PDF-printteri. Aja MikäPrintteri-makro ja laita sen ilmoittama nimi Printterin arvoksi Tulosta-makroon:

        Sub MikäPrintteri()
            MsgBox Application.ActivePrinter
        End Sub

        Sub Tulosta()
            Printteri = "PDF-XChange Printer 2012 on Ne01:"
            Application.ActivePrinter = Printteri
            ActiveSheet.PageSetup.PrintArea = Range("B2:AO32")
            ActiveWindow.SelectedSheets.PrintOut Copies:=1, Collate:=True
        End Sub


      • Kalenterikalle

        Kiitos "Tämmönen" vastauksesta ja ehdotuksestasi. En nopeasti kokeillen saanut tulostettua kuin kapean kaistaleen taulukostani. Voisitko hieman avata vaiheita, mitä koodillasi pitäisi tapahtua missäkin kohtaa. Auttaisi hahmottamaan työn kulkua.
        Ajatuksenihan oli, että saisin aina tulostettua saman alueen, vaikka osa sarakkeista "liukuukin" lukittujen sarakkeiden alle. Pitäisikö sinun koodisi toimia juuri näin?


      • väärinpäin
        Kalenterikalle kirjoitti:

        Kiitos "Tämmönen" vastauksesta ja ehdotuksestasi. En nopeasti kokeillen saanut tulostettua kuin kapean kaistaleen taulukostani. Voisitko hieman avata vaiheita, mitä koodillasi pitäisi tapahtua missäkin kohtaa. Auttaisi hahmottamaan työn kulkua.
        Ajatuksenihan oli, että saisin aina tulostettua saman alueen, vaikka osa sarakkeista "liukuukin" lukittujen sarakkeiden alle. Pitäisikö sinun koodisi toimia juuri näin?

        Veikkaisin että tekee lähes sen mitä pyysit, "eli alkaen aina solusta B2 30 saraketta ja B2 39 riviä".

        Tosin jos B-sarakkeeseen lisätään 30 saraketta, niin ollaan sarakkeessa AF, ja 2-riville 39 riviä, niin rivillä 40. Eli tuon koodissa olevan alueen muuttaisin muotoon "B2:AF40".

        Jos taas haluat tulostaa aina tietyn kokoisen alueen jostain solusta alkaen, niin helpoimmalla pääsee tekemällä makron, joka tekee edellisen koodin jutut, mutta alue on joku tyyliin "ActiveCell.Offset(39,30)". Tuolloin alueen vasen ylänurkka pitää aina valita hiirellä tai muulla tavalla, ja sitten ajetaan makro.


      • väärinpäin
        väärinpäin kirjoitti:

        Veikkaisin että tekee lähes sen mitä pyysit, "eli alkaen aina solusta B2 30 saraketta ja B2 39 riviä".

        Tosin jos B-sarakkeeseen lisätään 30 saraketta, niin ollaan sarakkeessa AF, ja 2-riville 39 riviä, niin rivillä 40. Eli tuon koodissa olevan alueen muuttaisin muotoon "B2:AF40".

        Jos taas haluat tulostaa aina tietyn kokoisen alueen jostain solusta alkaen, niin helpoimmalla pääsee tekemällä makron, joka tekee edellisen koodin jutut, mutta alue on joku tyyliin "ActiveCell.Offset(39,30)". Tuolloin alueen vasen ylänurkka pitää aina valita hiirellä tai muulla tavalla, ja sitten ajetaan makro.

        "joku tyyliin "ActiveCell.Offset(39,30)""

        Tai ei siis noin, koska tuo valitsee vain alueen oikean alanurkan. Ehkä pitää tehdä uusi range:

        Dim rng as Range
        Set rng = ActiveCell.Resize(39,30)

        Tuupata toi rng sitten PrintAreaksi.

        Resizestä: http://www.homeandlearn.org/the_resize_property.html


    • Kalenterikalle

      "väärinpäin "
      #Tosin jos B-sarakkeeseen lisätään 30 saraketta, niin ollaan sarakkeessa AF, ja 2-riville 39 riviä, niin rivillä 40. Eli tuon koodissa olevan alueen muuttaisin muotoon "B2:AF40".#

      - Totta, tarkkana saa olla. Laskiessani sarakkeita, mulla oli yksi "tarpeeton" sarake piilotettuna, eli näkymä on siis 32 saraketta ja 39 riviä.
      Näkymän lisäksi on A- marginaalisarake ja rivi 1 -marginaalirivi, joita ei huomioida tulostukseen.

      - Jos kalenteriani lähdetään laskemaan vuoden alusta, niin tarkasti laskien tuo "B2:AG40" -alue olisi ensimmäiset 4 viikkoa, jotka pitäisi tulostaa. Sen jälkeen tulostetaan seuraavat 4 viikkoa (28 solua), eli alkusolu on edelleen B2 31 saraketta, jolloin viimeisin sarake/rivi olisi BI40, eli edelliset 28 saraketta eivät näkyisi enää.

      ##Jos taas haluat tulostaa aina tietyn kokoisen alueen jostain solusta alkaen..##

      - Juu kyllä, edelleen ajatukseni oli juuri tuo..

      #"joku tyyliin "ActiveCell.Offset(39,30)""
      Tai ei siis noin, koska tuo valitsee vain alueen oikean alanurkan. Ehkä pitää tehdä uusi range:
      Dim rng as Range
      Set rng = ActiveCell.Resize(39,30)
      Tuupata toi rng sitten PrintAreaksi.
      Resizestä: http://www.homeandlearn.org/the_resize_property.html#

      - Tästä en oikein saanut kiinni..

      • väärinpäin

        Resizellä siis vaan suurennetaan valittua aluetta (ennen makroa valittua yhtä solua), ennen kuin siitä tehdään tulostusalue.


      • väärinpäin
        väärinpäin kirjoitti:

        Resizellä siis vaan suurennetaan valittua aluetta (ennen makroa valittua yhtä solua), ennen kuin siitä tehdään tulostusalue.

        Tein koodinpätkän, joka asettaa tulostusalueen taulukon oikean alapuolen ruudun vasemmasta yläkulmasta lukien, kun taulukko on kiinitetty neljäksi ruuduksi. Koodissa olevat muuttujat "rivit" ja "sarakkeet" määrittävät tulostusalueen koon. Jos vasemmalla ja/tai ylhäällä on aina tulostettavia rivejä, niin ne voi ottaa käyttöön sivun asettelujen "Tulosta otsikot"-ikkunan kautta.

        Sub asetatulostusalue()

        Dim rivit As Integer: rivit = 4
        Dim sarakkeet As Integer: sarakkeet = 4

        If ActiveWindow.Panes.Count = 4 Then
        Dim osoite As String
        Dim alue As Range
        osoite = ActiveWindow.Panes(4).VisibleRange.Address
        Set alue = Range(Left(osoite, InStr(osoite, ":") - 1))
        Set alue = alue.Resize(rivit, sarakkeet)
        ActiveWorkbook.ActiveSheet.PageSetup.PrintArea = alue.Address
        End If

        End Sub


    • Kundepuu

      Sub tulosta()
      ActiveSheet.PageSetup.PrintArea = ""
      'Jos kalenteriani lähdetään laskemaan vuoden alusta, niin tarkasti laskien tuo "B2:AG40" -alue olisi ensimmäiset 4 viikkoa, jotka pitäisi tulostaa.
      'Sen jälkeen tulostetaan seuraavat 4 viikkoa (28 solua), eli alkusolu on edelleen B2 31 saraketta, jolloin viimeisin sarake/rivi olisi BI40, eli edelliset 28 saraketta eivät näkyisi enää.

      'eka 4 viikkoa $E$1:$AG$40 Pane 2:ssa
      'seuraavat 4 viikkoa kerroit olevan alkusolu on edelleen B2 31 saraketta, jolloin viimeisin sarake/rivi olisi BI40
      'miksi ei ole sama eka ja toka ja mitern loput?
      'nythän sen pitäisi olla $E$1: $B$I40
      'jos sama niin silloin näin ja aina Pane2 vasen yläkulmasta lähtien
      'korjaa taulukkoasia ja muuta arvot sopiviksi sitten...
      ActiveSheet.PageSetup.PrintArea = ActiveWindow.Panes(2).VisibleRange.Cells(1, 1).Resize(40, 29).Address
      ActiveWindow.SelectedSheets.PrintOut From:=1, To:=1
      End Sub

      Keep EXCELing
      @Kunde

    • Kalenterikalle

      Moi kaikki jeesaajat, Kundea myöten.
      Tilanne on hieman muuttunut, kun sain kaivettua käsiini vanhan viestin, jossa oli Kunden sorvaama koodi tälle kalenterilleni. Vanha kalenterini ei sisältänyt tätä koodia, joten kaivoin sen Excel-sivuston kätköistä. Ja kuinkas kävikään, sain sen toimimaan halutulla tavalla muutamaa lukua muuttamalla.
      Vain aika näytää toimiiko tämä koodi luotettavasti koko vuoden, vai pitääkö jotain kohtaa viilata.

      Kerran vielä Kaikille ja Kundellekin kiitos jeesistä!

      Tässä alla kokonaisuudessaan tuo koodi.

      Sub luo_pdf()
      Dim x As Long
      Dim Sarake As String
      On Error Resume Next
      Application.DisplayAlerts = False
      Worksheets("Lomat2016").Activate
      Range("B3") = Format(Date, "dd.mm.yyyy")
      HaeEkasarake
      ActiveWindow.Panes(2).Activate
      x = ActiveWindow.Panes(2).ScrollColumn
      If x > 26 Then
      Sarake = Chr(Int((x - 1) / 26) 64) & Chr(((x - 1) Mod 26) 65)
      Else
      Sarake = Chr(x 64)
      End If
      Worksheets.Add().Name = "Huuhaa"
      Worksheets("Lomat2016").Range("B2:B40").Copy Worksheets("Huuhaa").Range("A1")
      Worksheets("Lomat2016").Range(Sarake & 2).Resize(39, 28).Copy Worksheets("Huuhaa").Range("B1")
      Worksheets("Huuhaa").Columns(1).AutoFit
      ActiveSheet.ResetAllPageBreaks
      ActiveWindow.View = xlPageBreakPreview
      ActiveSheet.VPageBreaks(1).DragOff Direction:=xlToRight, RegionIndex:=1
      Set ActiveSheet.VPageBreaks(1).Location = Range("AG1")
      ActiveWindow.View = xlNormalView
      With ActiveSheet.PageSetup
      .LeftMargin = Application.InchesToPoints(0.31496062992126)
      .RightMargin = Application.InchesToPoints(0.31496062992126)
      .Orientation = xlLandscape
      .FitToPagesWide = 1
      .FitToPagesTall = 1
      .Zoom = 53
      End With

      Worksheets("Huuhaa").Range("A1:AG40").Select
      Selection.ExportAsFixedFormat Type:=xlTypePDF, Filename:="D:\peedeeäffät\pdfkoe.pdf", _
      Quality:=xlQualityStandard, IncludeDocProperties:=True, IgnorePrintAreas _
      :=False, OpenAfterPublish:=True
      Worksheets("Huuhaa").Delete
      Application.DisplayAlerts = True
      End Sub

      Sub HaeEkasarake()
      Päiväys = Date
      If weekDay(Date, vbMonday) = 6 Then
      Haku = Format(Date - 1, "d.m.")
      Päiväys = Päiväys - 1
      Else
      If weekDay(Date, vbMonday) = 7 Then
      Haku = Format(Date - 2, "d.m.")
      Päiväys = Päiväys - 2
      Else
      Haku = Format(Date, "d.m.")
      End If
      End If
      With Range("E4:JD4")
      Set Solu = .Find( _
      What:=Haku, _
      LookIn:=xlValues, _
      LookAt:=xlWhole, _
      SearchOrder:=xlByRows, _
      SearchDirection:=xlNext, _
      MatchCase:=False, _
      SearchFormat:=False)
      If Not Solu Is Nothing Then
      Set Löydetty = Solu
      EkaOsoite = Solu.Address
      Do
      Set Löydetty = Union(Löydetty, Solu)

      Set Solu = .FindNext(Solu)
      Loop While Not Solu Is Nothing And Solu.Address <> EkaOsoite
      End If
      End With
      End Sub

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

    Luetuimmat keskustelut

    1. Olen tosi outo....

      Päättelen palstajuttujen perusteella mitä mieltä minun kaipauksen kohde minusta on. Joskus kuvittelen tänne selkeitä tap
      Ikävä
      15
      2121
    2. Kotkalainen Demari Riku Pirinen vangittu Saksassa lapsipornosta

      https://www.kymensanomat.fi/paikalliset/8081054 Kotkalainen Demari Riku Pirinen vangittu Saksassa lapsipornon hallussapi
      Kotka
      84
      2068
    3. Oletko sä luovuttanut

      Mun suhteeni
      Ikävä
      101
      1367
    4. Hommaatko kinkkua jouluksi?

      Itse tein pakastimeen n. 3Kg:n murekkeen sienillä ja juustokuorrutuksella. Voihan se olla, että jonkun pienen, valmiin k
      Sinkut
      145
      1170
    5. Vanhalle ukon rähjälle

      Satutit mua niin paljon kun erottiin. Oletko todella niin itsekäs että kuvittelet että huolisin sut kaiken tapahtuneen
      Ikävä
      10
      1166
    6. Maisa on SALAKUVATTU huumepoliisinsa kanssa!

      https://www.seiska.fi/vain-seiskassa/ensimmainen-yhteiskuva-maisa-torpan-ja-poliisikullan-lahiorakkaus-roihuaa/1525663
      Kotimaiset julkkisjuorut
      79
      1122
    7. Aatteleppa ite!

      Jos ei oltaisikaan nyt NATOssa, olisimme puolueettomana sivustakatsojia ja elelisimme tyytyväisenä rauhassa maassamme.
      Maailman menoa
      249
      876
    8. Omalääkäri hallituksen utopia?

      Suurissa kaupungeissa ja etelässä moinen onnistunee. Suuressa osassa Suomea on taas paljon keikkalääkäreitä. Mitenkäs ha
      Maailman menoa
      171
      853
    9. Mitä sanoisit

      Ihastukselle, jos näkisitte?
      Tunteet
      62
      821
    10. Onko se ikä

      Alkanut haitata?
      Ikävä
      59
      811
    Aihe