Luvun pienentäminen solussa

Anonyymi

Moi,
Ytimekäs otsikkoni ei vielä paljasta mitä lopulta haluan, mutta tässä tarkemmin esimerkin valossa.

B -sarakkeessa on 36 nimeä riveillä 1-36.
A-sarakkeessa on jokaisen nimen kohdalla jokin arvo, vaikka väliltä 0-100.
Jokaisella nimellä on tarkastelualue rivin solut C-Z.
Tässä lähtöasetelma.

Ajatuksena olisi ainoastaan pienentää A-sarakkeen lukua hiirtä klikkaamalla soluissa välillä C-Z siten, että soluun jäisi X-kirjain, eikä X-kirjaimen poistaminen (joskus) -palauttaisi arvoa enää isommaksi.

Soluihin C-Z täytyy voida kirjoittaa haluttaessa muitakin kirjaimia, mutta VAIN X-kirjain pienentäisi A-sarakkeen lukua yhdellä.

Tarkennuksena siis, että jokainen rivin X-kirjain pienentää A-sarakkeen solun lukua.

Lisäksi A-sarakkeen lukua pitää voida muuttaa isommaksi tai pienemmäksi niin haluttaessa, eli lukua lähdetään aina pienentämään sen hetkisestä arvosta mikä siinä sillä hetkellä on, paisti jos arvo on 0 (nolla).

Luonnistuisiko tällainen kaavarivillä tai VB:llä?

12

138

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Anonyymi

      VB:llä hyvin luultavasti onnistuu. En ole täysin varma, ettei sille ole jotain estettä, mutta ohjelmointikielihän se on, joten äkkiseltään sanoisin, että mikä ettei.

      Kaavarivillä tuskin ihan tuollaisenaan onnistuu. Jotain samantapaista kyllä, mutta ainakin se, että solun arvo muuttuu sekä syöttämällä että kaavan avulla, on aika tekemätön paikka. Kun syötät A-sarakkeeseen uuden arvon, se ei vain muuta solun arvoa, vaan korvaa solun kaavan.

      • Anonyymi

        Tuota itsekin arvelin, ettei A-sarakkeen arvoa voi ainakaan suoraan lähteä muokkaamaan, ainakaan jos se sisältää kaavan. En tiedä onnistuisiko tämä lainkaan kkaavalla.
        Mutta nyt näyttääkin Kunde alempana ratkaisseen asian VB:llä.
        Kiitos silti pähkäilystäsi!


    • ko taulukon moduuliin...
      nyt tuplaklikkaamalla solua alueella lisää soluun X ja pienentää vastaavan solun rivin A sarakkeen arvoa -1 ja jos nolla ei tee mitään.

      Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
      If Not Intersect(Range("C1:Z36"), Target) Is Nothing Then
      Target = "X"
      If Range("A" & Target.Row) = 0 Then
      Else
      Range("A" & Target.Row) = Range("A" & Target.Row) - 1
      Target.Offset(0, 1).Select
      End If
      End If
      End Sub

      • sori tämäkoodi piti postata...

        Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
        If Not Intersect(Range("C1:Z36"), Target) Is Nothing Then
        If Target = "X" Then
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        Else
        Target = "X"
        If Range("A" & Target.Row) <= 0 Then
        Range("A" & Target.Row) = 0
        Else
        Range("A" & Target.Row) = Range("A" & Target.Row) - 1
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        End If
        End If
        End If
        End Sub

        Keep EXCELing
        @Kunde


      • Anonyymi
        kunde kirjoitti:

        sori tämäkoodi piti postata...

        Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
        If Not Intersect(Range("C1:Z36"), Target) Is Nothing Then
        If Target = "X" Then
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        Else
        Target = "X"
        If Range("A" & Target.Row) <= 0 Then
        Range("A" & Target.Row) = 0
        Else
        Range("A" & Target.Row) = Range("A" & Target.Row) - 1
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        End If
        End If
        End If
        End Sub

        Keep EXCELing
        @Kunde

        Kiitos Kunde, tämä näyttäisi ns. soivalta peliltä.
        Esitin asiani esimerkin valossa, kuten kirjoitinkin. Nyt kun käsissäni on toimiva koodi, yritän sovittaa sen jo käytössä olevaan versiooni.
        Mahdollisissa ongelmissa käännyn mielelläni puoleesi.
        Virittelyni siirtyy varmaan kyllä ensi viikolle, mutta palataan tarvittaessa asiaan.
        Kiitos vielä kovasti nopeasta reagoinnistasi! :)


      • Anonyymi
        Anonyymi kirjoitti:

        Kiitos Kunde, tämä näyttäisi ns. soivalta peliltä.
        Esitin asiani esimerkin valossa, kuten kirjoitinkin. Nyt kun käsissäni on toimiva koodi, yritän sovittaa sen jo käytössä olevaan versiooni.
        Mahdollisissa ongelmissa käännyn mielelläni puoleesi.
        Virittelyni siirtyy varmaan kyllä ensi viikolle, mutta palataan tarvittaessa asiaan.
        Kiitos vielä kovasti nopeasta reagoinnistasi! :)

        Moi Kunde. Päätinkin kokeilla koodiasi heti ja mieleeni tuli seuraavaa.
        Tässä nykyisessä versiossahan tuo X-kirjain pienentää A-sarakkeen solun arvoa yhdellä.
        Olisiko iso muutos jos X-kirjaimen poistamisen jälkeen se palauttaisikin arvon entiselleen?
        Ajatus muutokselle lähti siitä, että nuo X-kirjaimet periaatteessa jäävät yleensä aina paikalleen, mutta joskus tulee tilanne, että se täytyykin poistaa ja arvo saisi palautua sillä yhdellä silloin. Soluun muiden kirjainten kirjoittaminen saisi olla silti voimassa edelleen, vaikka X-kirjain poistettaisiinkin.

        Toinen muutos mikä tuli mieleen, voisiko koodiasi muuttaa siten, että se vaikuttaisikin vain joka toisella rivillä, eli nyt se vaikuttaa joka rivillä 1-36, kun se voisikin selvyyden vuoksi vaikuttaa vain joka toisella rivillä, eli 1, 3, 5, 7....... 35.

        Tämä muutos olisi tervetullut. :))


      • Anonyymi kirjoitti:

        Moi Kunde. Päätinkin kokeilla koodiasi heti ja mieleeni tuli seuraavaa.
        Tässä nykyisessä versiossahan tuo X-kirjain pienentää A-sarakkeen solun arvoa yhdellä.
        Olisiko iso muutos jos X-kirjaimen poistamisen jälkeen se palauttaisikin arvon entiselleen?
        Ajatus muutokselle lähti siitä, että nuo X-kirjaimet periaatteessa jäävät yleensä aina paikalleen, mutta joskus tulee tilanne, että se täytyykin poistaa ja arvo saisi palautua sillä yhdellä silloin. Soluun muiden kirjainten kirjoittaminen saisi olla silti voimassa edelleen, vaikka X-kirjain poistettaisiinkin.

        Toinen muutos mikä tuli mieleen, voisiko koodiasi muuttaa siten, että se vaikuttaisikin vain joka toisella rivillä, eli nyt se vaikuttaa joka rivillä 1-36, kun se voisikin selvyyden vuoksi vaikuttaa vain joka toisella rivillä, eli 1, 3, 5, 7....... 35.

        Tämä muutos olisi tervetullut. :))

        Lisäsin koodiin vielä semmoisen, että jos A -sarakkeen luku on jo 0, niin ei voi lisätä X kirjainta- jos ei hyvälisäys, niin poistetaan sitten...

        Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
        If Not Intersect(Range("C1:Z36"), Target) Is Nothing Then
        If Target.Row Mod 2 = 1 Then
        If Target = "X" Then
        Target = ""
        Range("A" & Target.Row) = Range("A" & Target.Row) 1
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        Else
        If Range("A" & Target.Row) <= 0 Then
        Range("A" & Target.Row) = 0
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        Else
        Range("A" & Target.Row) = Range("A" & Target.Row) - 1
        Target = "X"
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        End If
        End If
        End If
        End If
        End Sub

        Keep EXCELing
        @Kunde


      • Anonyymi
        kunde kirjoitti:

        Lisäsin koodiin vielä semmoisen, että jos A -sarakkeen luku on jo 0, niin ei voi lisätä X kirjainta- jos ei hyvälisäys, niin poistetaan sitten...

        Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
        If Not Intersect(Range("C1:Z36"), Target) Is Nothing Then
        If Target.Row Mod 2 = 1 Then
        If Target = "X" Then
        Target = ""
        Range("A" & Target.Row) = Range("A" & Target.Row) 1
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        Else
        If Range("A" & Target.Row) <= 0 Then
        Range("A" & Target.Row) = 0
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        Else
        Range("A" & Target.Row) = Range("A" & Target.Row) - 1
        Target = "X"
        If Target.Column = 25 Then
        Target.Offset(1, 0).Select
        Else
        Target.Offset(0, 1).Select
        End If
        End If
        End If
        End If
        End If
        End Sub

        Keep EXCELing
        @Kunde

        Kunde, laitoinkin aiheesta spostia sulle!


    • Anonyymi

      Näinhän se parempi toimisto-ohjelma asentuu vaikeasti komentamalla ;-).
      (täällä kerran winhiihuli vai kuka se oli, niin valitti sudotuksesta, joten...:

      apt update

      sudo !!

      apt upgrade

      sudo !!

      apt search libreoffice

      apt install libreoffice

      sudo !!

      xxx

      $ e
      Keskeyt ä.............
      .

      • Anonyymi

        Mitäs tehdään, kun heti tuli:

        bash: apt: komentoa ei löydy

        -


      • Anonyymi

        Niin... Miksipä ihmeessä kukaan haluaisi käyttää hyvin optimoitua ammattilaisten tekemää kaupallista ohjelmistoa, kun voi yhtä hyvin käyttää huonosti optimoitua harrastelijoiden vapaaehtoisprojektina tekemää ilmaiskopiota samasta tuotteesta.


    • Anonyymi

      Moi,
      Aiheen aloittajana ilmoitan, että sain ratkaisun esittämääni ongelmaan! Kiitos kaikille ratkaisuja esittäneille ja erityisesti Kundelle, joka väänsi homman toimimaan VB-koodilla -joka saikin matkan varrella lisää uusia ulottuvuuksia.

      -aiheen aloittaja

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

    Luetuimmat keskustelut

    1. Voiko normaali ihminen ryhtyä vasemmistolaiseksi?

      Tätä jäin pohdiskelemaan.
      Maailman menoa
      210
      4329
    2. SDP haluaa 40 000 nettomaahanmuuttajaa

      SDP:n Suunnanmuutos-vaihtoehtobudjetissa, käy ilmi, että demarit itse asiassa vaativat räjähdysmäistä ”työperäisen” maah
      Maailman menoa
      146
      3818
    3. Orpo: Velkajarrua vastustavaa puoluetta vaikea ajatella hallitukseen

      No Minja Koskelan kommunistipuolue jäi ulos tuosta. Kaikki eduskuntapuolueet vasemmistoliittoa lukuun ottamatta sopivat
      Maailman menoa
      139
      3290
    4. SDP jo 100 % suositumpi kuin persut

      Kertoo Hesarin uusin kannatuskysely. Demareiden kannatus on miltei tuplat verrattuna persuihinl. Suomen kansa ei selväst
      Maailman menoa
      12
      2755
    5. Hienoa! Eduskunta luopui käteisen käytöstä

      Nyt tuo sama muutos pitää saada myös muuhun yhteiskuntaan. Käteistähän ei tarvitse tänä päivänä enää kuin rikolliset.
      Maailman menoa
      56
      1665
    6. Mikä tämä henkilö mahtaa touhuta Parkanossa

      Kamalaa https://www.ylasatakunta.fi/teksti/pirkanmaan-karajaoikeus-vangitsi-koiran-tappamisesta-epaillyn-6.68.127794.b58
      Parkano
      35
      1631
    7. Ikävä sinua mies

      Vuosia kuluu, mutta tunteet ei ole hävinnyt. Tasoittuneet toki, kun ei olla nähty. Järki palannut päähän kuitenkin. Se i
      Ikävä
      19
      1628
    8. Sulla on avaimet ja keinot

      Jos haluat jatkaa tutustumista. Itse olen niin jäässä etten pysty tekemään enää mitään. Pidempi keppi johon on helpompi
      Ikävä
      25
      1405
    9. Orpo loukkaantui fasismiin viittaavasta sanavalinnasta

      Mutta miksi loukkaantui? Orpohan on tehnyt yhteistyötä fasistien kanssa jo vuonna 2019, siis jo neljä vuotta ennen loukk
      Maailman menoa
      27
      1361
    10. Kiinnostaa - ei kiinnosta - kiinnostaapas

      Selittäkää hämmentyneelle miksi miehiä ei ikinä kiinnosta silloin, kun sitä olisi itsekin kiinnostunut? Sitten kun siirt
      Sinkut
      122
      1206
    Aihe