Ehdollinen laskenta

\\kyselee apuja

Käytössä xp pro excel 2003.
Yritän tehdä makroa joka laskee solun arvon mukaan kaavalla.
Negatiivisellä arvolla G$7-ko.solun arvo-I$1.
Positiivisellä arvolla G$7 ko.solun arvo I$1.
Nolla-arvolla G$7.
Alla kokeilun tulos (eipä toimi..):

Sub koe()
Dim Lähdealue2 As Range
Dim vika2 As Integer


vika2 = Range("D65536").End(xlUp).Row
Set Lähdealue2 = Range("D5:D" & vika2)
Range("K5").Select

For i = 1 To Lähdealue2.Count
ActiveCell = Lähdealue2(i)

If ActiveCell.Value = "" Then
ActiveCell.FormulaR1C1 = "=R[2]C[-4] RC[-7]"
If ActiveCell.Value > "0" Then
ActiveCell.FormulaR1C1 = "=R[2]C[-4]"
If ActiveCell.Value < "0" Then
ActiveCell.FormulaR1C1 = "=R7C[-4]-RC[-7]-R1C[-2]"
ActiveCell.Offset(1, 0).Select
End If
End If
End If

Next

Range("A1").Select

End Sub

Oliskohan kenelläkään vinkkiä asiaan?

12

843

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • ...

      Ainakin lainausmerkit pois nollan ympäriltä.

      • \\kyselee apuja

        Otin lainausmerkit pois, eipä auttanut.
        Tulos tuli vain K5 soluun (ja sekin väärin).

        Olisiko lisää ehdotuksia, kaikki vinkit otetaan kiitollisuudella vastaan.


      • ...
        \\kyselee apuja kirjoitti:

        Otin lainausmerkit pois, eipä auttanut.
        Tulos tuli vain K5 soluun (ja sekin väärin).

        Olisiko lisää ehdotuksia, kaikki vinkit otetaan kiitollisuudella vastaan.

        Pari elseä lisää: Else If ActiveCell
        Toinen ongelma on, että kaava sijoitetaan samaan soluun, jossa on luku ennestään.


      • \\kyselee apuja
        ... kirjoitti:

        Pari elseä lisää: Else If ActiveCell
        Toinen ongelma on, että kaava sijoitetaan samaan soluun, jossa on luku ennestään.

        Lähtötiedot ovat solusta D5 alaspäin, tulokset laskennasta haluaisin solusta K5 alaspäin. Ennen laskentaa solu ompi tyhjä.


      • ...
        \\kyselee apuja kirjoitti:

        Lähtötiedot ovat solusta D5 alaspäin, tulokset laskennasta haluaisin solusta K5 alaspäin. Ennen laskentaa solu ompi tyhjä.

        For Each solu In Lähdealue2
        arvo = solu.Value

        If arvo = 0 Then
        ActiveCell.FormulaR1C1 = "=R[2]C[-4] RC[-7]"
        Else If arvo > 0 Then
        ActiveCell.FormulaR1C1 = "=R[2]C[-4]"
        Else If arvo < 0 Then
        ActiveCell.FormulaR1C1 = "=R7C[-4]-RC[-7]-R1C[-2]"
        End If
        End If
        End If
        ActiveCell.Offset(1, 0).Select
        Next
        ?


      • \\kyselee apuja
        ... kirjoitti:

        For Each solu In Lähdealue2
        arvo = solu.Value

        If arvo = 0 Then
        ActiveCell.FormulaR1C1 = "=R[2]C[-4] RC[-7]"
        Else If arvo > 0 Then
        ActiveCell.FormulaR1C1 = "=R[2]C[-4]"
        Else If arvo < 0 Then
        ActiveCell.FormulaR1C1 = "=R7C[-4]-RC[-7]-R1C[-2]"
        End If
        End If
        End If
        ActiveCell.Offset(1, 0).Select
        Next
        ?

        tulipa compile error for without next.

        hmm..ei tämä ollutkaaan helppoa...mitähän seuraavaksi....netistä yrittänyt apua löytää, ilman mainittavaa menestystä..


      • \\kyselee apuja kirjoitti:

        tulipa compile error for without next.

        hmm..ei tämä ollutkaaan helppoa...mitähän seuraavaksi....netistä yrittänyt apua löytää, ilman mainittavaa menestystä..

        kyllä se siitä treenaamalla...

        Sub koe()
        Dim Lähdealue2 As Range
        Dim vika2 As Integer

        vika2 = Range("D65536").End(xlUp).Row
        Set Lähdealue2 = Range("D5:D" & vika2)
        For Each solu In Lähdealue2
        Select Case solu
        Case Is > 0
        solu.Offset(0, 7) = Val(Range("G7")) Val(solu) Val(Range("I1"))
        Case Is < 0
        solu.Offset(0, 7) = Val(Range("G7")) - Val(solu) - Val(Range("I1"))
        Case 0
        solu.Offset(0, 7) = Val(Range("G7"))
        End Select
        Next
        End Sub


      • \\kyselee apuja
        kunde kirjoitti:

        kyllä se siitä treenaamalla...

        Sub koe()
        Dim Lähdealue2 As Range
        Dim vika2 As Integer

        vika2 = Range("D65536").End(xlUp).Row
        Set Lähdealue2 = Range("D5:D" & vika2)
        For Each solu In Lähdealue2
        Select Case solu
        Case Is > 0
        solu.Offset(0, 7) = Val(Range("G7")) Val(solu) Val(Range("I1"))
        Case Is < 0
        solu.Offset(0, 7) = Val(Range("G7")) - Val(solu) - Val(Range("I1"))
        Case 0
        solu.Offset(0, 7) = Val(Range("G7"))
        End Select
        Next
        End Sub

        Kokeilenpa huomenna, kun saan widoosakoneen taas käsiini.

        Kiitän makrosta jo etukäteen.

        Kunde, muistaakseni avaat omat excel-sivut jossain vaiheessa?


      • \\kyselee apuja kirjoitti:

        Kokeilenpa huomenna, kun saan widoosakoneen taas käsiini.

        Kiitän makrosta jo etukäteen.

        Kunde, muistaakseni avaat omat excel-sivut jossain vaiheessa?

        joo kyllä Kunden portaali aukeaa virallisestikin kevään aikana. Varmuuskopiot serveriltä vaan menivät "vituiksi" ja joudun manuaalisesti tekeen juttuja uusiksi. Portaaliin tulee aluksi osiot CAD/CAM/CNC, EXCEL(myöhemmin muut officejutskat) ja MATKAILU lähinnä nyt THAIMAA (Khorat ja Pattaya). Varsinkin CAD/CAM/CNC osaajat voisivat lähettää mulle mailia [email protected]

        KEEP EXCELING
        Kunde


      • \\kyselee apuja
        kunde kirjoitti:

        joo kyllä Kunden portaali aukeaa virallisestikin kevään aikana. Varmuuskopiot serveriltä vaan menivät "vituiksi" ja joudun manuaalisesti tekeen juttuja uusiksi. Portaaliin tulee aluksi osiot CAD/CAM/CNC, EXCEL(myöhemmin muut officejutskat) ja MATKAILU lähinnä nyt THAIMAA (Khorat ja Pattaya). Varsinkin CAD/CAM/CNC osaajat voisivat lähettää mulle mailia [email protected]

        KEEP EXCELING
        Kunde

        Kerro sitten tarkemmin kun saat portaalin auki, kiitos.

        Makrosta vielä:
        D6 0.03 G7 236.02 I1 9.44 tulokseksi antaa (K5) 236.00

        Olisiko mahdollista saa desimaaleja mukaan?


      • \\kyselee apuja kirjoitti:

        Kerro sitten tarkemmin kun saat portaalin auki, kiitos.

        Makrosta vielä:
        D6 0.03 G7 236.02 I1 9.44 tulokseksi antaa (K5) 236.00

        Olisiko mahdollista saa desimaaleja mukaan?

        nyt desimaalitkin mukana ;-)

        Sub koe()
        Dim Lähdealue2 As Range
        Dim vika2 As Integer

        vika2 = Range("D65536").End(xlUp).Row
        Set Lähdealue2 = Range("D5:D" & vika2)
        For Each solu In Lähdealue2
        Select Case solu
        Case Is > 0
        solu.Offset(0, 7) = CDbl(Range("G7")) CDbl(solu) CDbl(Range("I1"))
        Case Is < 0
        solu.Offset(0, 7) = CDbl(Range("G7")) - CDbl(solu) - CDbl(Range("I1"))
        Case 0
        solu.Offset(0, 7) = CDbl(Range("G7"))
        End Select
        Next
        End Sub


      • \\kyselee apuja
        kunde kirjoitti:

        nyt desimaalitkin mukana ;-)

        Sub koe()
        Dim Lähdealue2 As Range
        Dim vika2 As Integer

        vika2 = Range("D65536").End(xlUp).Row
        Set Lähdealue2 = Range("D5:D" & vika2)
        For Each solu In Lähdealue2
        Select Case solu
        Case Is > 0
        solu.Offset(0, 7) = CDbl(Range("G7")) CDbl(solu) CDbl(Range("I1"))
        Case Is < 0
        solu.Offset(0, 7) = CDbl(Range("G7")) - CDbl(solu) - CDbl(Range("I1"))
        Case 0
        solu.Offset(0, 7) = CDbl(Range("G7"))
        End Select
        Next
        End Sub

        Toimii hienosti, eikä ole mitään anteeksipyydettävää vapaaehtoisesta avusta.


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

    Luetuimmat keskustelut

    1. IL - PerSut tykittää - Vaaralliset tappajat vankilaan jopa loppuelämäksi!!

      Entistä rajumpi elinkautinen tulee – Vaaralliset tappajat vankilaan jopa loppuelämäksi Henkirikosten uusijat voidaan ja
      Maailman menoa
      196
      22592
    2. Some kuhisee Sanna Marinista: "Wau"

      Sanna Marinia hehkutetaan. Muun muassa Jodelissa kommentoidaan The Sunday Timesin julkaisemaa kuvaa Marinista. Hän ant
      Maailman menoa
      99
      9869
    3. Sannalla tänään vuorossa The Daily Show

      Eli nyt mennään jo satiirin puolelle. Tuohan on vähän kuten Lindströmin ohjelma Suomessa.
      Maailman menoa
      54
      7748
    4. Äärioikeistopurran nukke Petteri Lapanen paniikissa

      Kun Suomen historian paras pääministeri antoi vankan lausunnon, kuinka "keskustelu politiikassa on käpertynyt lähinnä va
      Maailman menoa
      102
      6529
    5. SIELTÄ SE TULI: Kepu-Kurvinen: "Emme enää lähde punavihreään hallitukseen"

      Nyt muuten nauretaan loppuviikko, että tähänkö kaatui Lindtmanin pääministerihaaveet. "Antti Kurvisen mukaan puolue ei
      Maailman menoa
      193
      6247
    6. Tanskassa lain vaatimana Bovaer tappanut nautoja ja sairastuttanut

      Samaa myrkkyä myös Suomen lehmiin ollut tuloillaan, miten teidän tilalla? https://www.agriland.ie/farming-news/bovaer-m
      Maailman menoa
      67
      5861
    7. Ruotsalaisuuden Päivän virallinen liputuspäivä poistettava VÄLITTÖMÄSTI!

      Suomen valtion ja suomalaisuuden kannalta ei ole minkäänlaisia perusteita liputtaa virallisesti ruotsalaisuuden päivää,
      Maailman menoa
      61
      5350
    8. Täysi ryöpytys Sanna Marinille ulkomailla.

      https://www.iltalehti.fi/ulkomaat/a/f699d84f-fa53-4dba-8718-2c395017fc55 Sanna Marinin kirja saa todella tylyn vastaanot
      Maailman menoa
      51
      5243
    9. HS - Sanna Marinin kirja on priimaluokan vedätys!

      Kirja-arvio|Toivo on tekoja tulisi ensisijaisesti nähdä maineen rahallisen hyödyntämisen voimaannuttavana merkkipaaluna.
      Maailman menoa
      124
      4890
    10. Minja Koskelan "istumista" kertovassa uutisessa ei sanottu persuista mitään

      eli jälleen kerran äärivasemmistolainen valehtelee, hän kun väittää että juuri persut ovat lähetelleet Koskelalle vähemm
      Maailman menoa
      108
      4592
    Aihe