Příspěvky uživatele


< návrat zpět

Strana:  1 ... « předchozí  267 268 269 270 271 272 273 274 275   další » ... 289

Vyskúšajte toto, urobil som to aj na D, N, očr, akurát netuším, či som trafil správne stĺpce.

Toto dajte do I3 s Ctrl+Shift+Enter. Potom nakopírujte do potrebného počtu riadkov. Ale ako vidíte bolo by potrebné nastaviť dynamickú oblasť (posledný riadok). Budete s tým vedieť pohnúť ?
=IFERROR(INDEX($C$2:$C$23&" vs. "&$D$2:$D$23;MATCH(G3;IF($B$2:$B$23=H3;$A$2:$A$23);0));"")

Urobil som Vám možnosť si zvoliť, ktoré údaje sa pri splnení podmienky budú mazať. Máte tam aj použitie funkcie COUNTA s vrátenou chybou ak je 0, dá sa to použiť napr. pri dynamickom rozbaľovacom zozname (Vaše použitie COUNTA ako som písal nepoznám).

Pozrite si toto. Upravil som Vám tam filter aj pre "všeobecné chyby (desky laser)", a nastavil automatické formátovanie orámovania pri každom riadku, v ktorom je nejaká hodnota, pre všetky 3 listy. Teda orámovanie nebude presahovať tabuľku.

Môže to byť takto ako je to teraz urobené v "opravené chyby (desky laser)" ?
Ak áno, tak Vám tak urobím aj ostatné listy, keď je treba. Stačí potom iba klik na filter v prvom stĺpci a dať zoradiť zostupne či vzostupne. Lenže predtým, je treba rozdeliť všetky zlúčené bunky. Preto Vám to nešlo.

ClearContents riadky nemaže. Maže iba obsah. Budete mať "deravú" tabuľku. Tam kde používate to COUNTA() dajte napr.
=IF(COUNTA(A3:A978)=0;ERF(;);COUNTA(A3:A978))
a vráti Vám to chybu #NEDOSTUPNÝ, a nie A2:A2. Alebo proste iba testujte 0. Neviem aké máte presne použitie toho COUNTA, čo robíte s výsledkom ďalej...

Tú chybu na vyššie spomínanom riadku spôsobuje to, že ak si zmením dátum napr. na dnešný, že chcem začínať od dnes, tak treba zmeniť aj názov listu na číslo dnešného dňa, inak vzniká odkaz na neexistujúci list. Potom už to ide ako ste zamýšľal. Ešte by som tam ale doplnil uloženie nového xlsx po jeho vyplnení, nielen jeho otvorenie. A uloženie iba dát, bez vzorcov, ak bude ten súbor napr. poslaný mailom, bez Master súboru, dostane otravnú hlášku o prepojení.

Ale Vy ste ani nespomínal, že chcete kopírovať aj makrá. Vy ste spomínal, že chcete vytvoriť z dát, ktoré máte v 0.xlsm, výber určitých dát, a tento výber potom uložiť v novom zošite 1.xlsx. Netuším načo by tam mali byť makrá. Vy predsa ukladáte hotový plán, hotový zošit, bez tlačítok, teda aj bez makier.
Ten skrytý list je iba ako forma-vzor. do nového zošitu sa nakopíruje, ale nie skrytý, ani žiadny iný skrytý tam nieje.
Ja som Vás pochopil tak, že tam majú byť už len vypočítané dáta, čiže už aj bez vzorcov, že je to do prevádzky, zákazníkovi, proste niekam ako finálny zošit.
Prípadne ešte upresnite.

Kolega ma predbehol. Ale dám aj svoje riešenie.

EDIT: Pozerám, že Vy ste riešil a kopec ďalších vecí, ktoré dotyčný ešte ani nespomenul, super.
Havaruje mi to na tomto riadku
rBunka.Formula = Replace(rBunka.Formula, "01'!", Format(dDen, "dd") & "'!")
Pravá časť je OK, a priradenie vzorca píše Applicatio-defined or Object-defined Error. To nechápem.
Inak tú kópiu sme urobili veľmi podobne :)

Áno poznám, najskôr som mu ju tam chcel dať, naschvál som mu tam dal jeho vzorec, a ešte som zdôraznil použitie tohto vzorca, a čakám na reakciu, aby som sa mohol opýtať, ako presne má ten prepočet fungovať. Či je to takto správne, lebo rozdiel napr. 10 dní vyhodnotí ako 0, ak je to v jednom mesiaci, a ako 1 ak je to na prelome. Neviem ako sa to má v jeho obore počítať.
Stačí v makre zmeniť priradenie do poľa na:
DateDiff("m", PoleD(i, 1), Dnes)

Opäť a zasa netušíme o čo ide, ale ak len o hromadné prepočítanie v nejakom stĺpci pomocou makra s použitím Vášho vzorca, tak toto vypočíta výsledok celého stĺpca C a vloží do D počet mesiacov. Neviem ale, či to bude rýchlejšie, ako keby ste tam mali vzorce. Vyskúšajte.
Sub Meciacov()
Dim PoleD(), PoleM() As Integer, i As Long, MM As Integer, Dnes As Date, R As Long
With ThisWorkbook.Worksheets("Hárok1")
Dnes = .Cells(2, 12)
R = .Cells(.Rows.Count, "C").End(xlUp).Row - 1
PoleD = .Cells(2, 3).Resize(R).Value
ReDim PoleM(1 To UBound(PoleD))
For i = LBound(PoleD) To UBound(PoleD)
PoleM(i) = (Year(Dnes) - Year(PoleD(i, 1))) * 12 + Month(Dnes) - Month(PoleD(i, 1))
Next i
.Cells(2, 4).Resize(R).Value = Application.Transpose(PoleM)
End With
End Sub

Nech sa páči. Máte tam aj kontrolu, aby sa nevypisovala chyba, ak sa hodnota nenájde, aby sa nevypisovala 0 ak je bunka v List3 prázdna, a aby sa nekontrolovalo, ak je v List1 v B nevyplnený údaj.
Opravil som Vám aj nezmyselné vzorce na spočítanie oblasti v riadku 36 a v bunkách N40 a N41.
Snáď OK.

EIDT: PS: Treba si ešte upraviť/opraviť orámovanie buniek v stĺpcoch A,B,C. Neviem, či ste to zamýšľal takto.

Môžete prosím ešte raz napísať ktorý stĺpec z List3 sa má kopírovať do ktorého stĺpca Listu1 ?

3 >> 1
C -> D (určite ??? nie náhodou D -> D)
D -> E (určite ??? nie náhodou E -> E)
R -> R (určite ??? nie náhodou F -> R)
S -> S (určite ??? nie náhodou G -> S)

Už mi to docvaklo. Spomenul som si na podobný problém, spomenutý tu na fóre, pri Step -1 v cykle.
CDbl som tam mal, ale pri skúšaní všemožných typov asi v nesprávnej kombinácii s typom výsledku. To je vlastne aj dôvod prečo tam ostalo Double = náhodou.
Niekedy stačí namiesto bezhlavého skúšania, sa zastaviť, porozmýšľať, a možno niečo cvakne.
Na tom by ale ešte mohli aj súdruhovia z MS zapracovať, že ak ľavá strana priradenia je napr. Long, tak bude s číslami na pravej strane pracovať ako s Long, aj keď sú tieto čísla menšie. No ale čo už. Ďakujem opäť za ozrejmenie.

Tu sú obe riešenia, máte to už hotové, ale aj tak to sem dávam preto, lebo som narazil na zaujímavý problém. V popise makra to je opísané.
Ak vynásobím 1000*1000 dostanem OverFlow, tak si na to dajte pozor, ak budete podobným spôsobom vypočítavať priebeh.


Strana:  1 ... « předchozí  267 268 269 270 271 272 273 274 275   další » ... 289

Uživatelské menu

Nejste přihlášen(a)
avatar\n

Menu

On-line nástroje

Formulář Faktura

Formulář Faktura IV

Oblíbený formulář Faktura byl vylepšen a rozšířen.
Více se dočtete zde.

Aktivní diskuse

Týden v roce

Petr92 • 16.7. 15:34

Řazení podle času v kategoriích

veny • 16.7. 11:34

špatný výpočet ze zisku - příčina?

Anonym • 12.7. 22:56

špatný výpočet ze zisku - příčina?

Jakoby • 12.7. 12:35

Řazení podle času v kategoriích

Marekh • 12.7. 9:55

Porovnávací Tabulka

Jess • 8.7. 20:49

Vzorec pro zkopírování obsahu buňky.

veny • 6.7. 8:28