Anonymní profil gna – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

Anonymní profil gna – Programujte.comAnonymní profil gna – Programujte.com

 

Příspěvky odeslané z IP adresy 213.211.51.–

gna
C / C++ › ASM v gcc a C99:?
19. 6. 2017   #216749

gcc a vc nejsou kompatibilní. armc neznám.

gna
C / C++ › ASM v gcc a C99:?
19. 6. 2017   #216745

Tak to bych si tipnul, že to chceš pro MSVC. To by bylo dobré zmínit.

int i, x;

__asm
{
	mov eax, x
	mov i, eax
}
gna
C / C++ › ASM v gcc a C99:?
18. 6. 2017   #216742

Uvedením standardu pro kompilaci jen přijdeš o nestandardní rozšíření. Jinak asm, __asm, __asm__ fungují stejně. Správně je třetí varianta, která by měla fungovat vždycky.

gna
Python › Problém s funkcí
18. 6. 2017   #216741

Chyba je jasná, ale nevím o co se pokoušíš. Co od tohodle čekáš? 

x = list(anyth)

Z toho kódu netuším, co chceš aby to dělalo, tak to nedokážu opravit. Celkově z toho mám pocit, že to půjde o hodně jednodušeji. Co je to za algoritmus?

gna
Java › Chyba glassfish server
11. 6. 2017   #216707

Asi by nebylo težké podívat se, která z těch proměnných je null. Třeba getParameter vrací null, pokud parametr neexistuje.

gna
Java › Pořadí prováděných metod
9. 6. 2017   #216692

#4 Honza228
Pokud ty metody voláš někde, kde to blokuje překreslování okna, tak se překreslí až potom. Zmínil jsi nějaké hlavní vlákno a netuším, co jsi čekal od sleepu, ale jestli toto běží v samostatném vlákně, tak něco děláš špatně. (A když sis myslel, že se ty metody nevolají postupně, tak nejspíš všechno.)

gna
C / C++ › Max počet zobrazených řádek…
9. 6. 2017   #216672

Konzole ve Windows má standadrně výšků 25 řádků a buffer 300 řádků.

Jde to změnit v nastavení okna - levé myšítko na ikonu vlevo nahoře, nebo pravé myšítko kdekoli na záhlaví okna.

Nebo příkazem mode:

mode con lines=...

Taky můžeš výstup programu přesměrovat do souboru:

mujprogram >soubor
gna
C / C++ › Visual Studio 2015 nezná get…
8. 6. 2017   #216632

Je tam verze se dvěmi a třemi parametry. Ty dáváš jen jeden.

První parametr má být ukazatel na pole znaků, do kterého se má načítat. Ty máš v prvním volání ipAddress, což sice je ukazatel, ale nikam neukazuje. V druhém volání máš filePathName, což je jen znak, ne ukazatel.

Na té stránce je i příklad. 

char name[256];
std::cin.getline (name,256);

Spousta začátečníků řetězcům jako ukazatelům na pole znaků nerozumí. To nevadí, protože je k ničemu nepotřebuješ.

std::string name;
std::getline(std::cin, name);
gna
C / C++ › Nefunguje ReadFile() pri čít…
7. 6. 2017   #216619

O bufferu to nic neví. Může testovat jestli je [buffer, buffer+velikost) v zapisovatelné paměti. Tam problém asi nebude. Taky to nenačte více, než o kolik sis řekl, takže to nikam jinam nic nezapíše a ani v tom problém nebude (pokud teda nezkoušíš více než těch 1000, co ten buffer teď má).

Ale jinak to "povědomí" má. Přesně zná velikosti reportu a musíš ho načíst celý, jinak to nevrátí nic.

Čtení v timeru je taky super na ladění :)

Jak píše hu, zkus nějakou hotovou knihovnu. A ten C# taky není težký.

gna
C / C++ › Nefunguje ReadFile() pri čít…
7. 6. 2017   #216601

#6 iridium
Buffer je pravděpodobně platný, problém bude v uvedené délce.

Ale jestli tam máš ještě španě CRC, tak nevím, jestli něco načteš.

gna
Příkazový řádek › Sestavení regulárního výrazu
6. 6. 2017   #216598

Čekal jsem, že vim trochu znáš.

aktualni radek   :.!awk 'BEGIN{FS=OFS=";"} {print $4,$2,$3,$1}'
oznaceny vyber   :'<,'>!awk 'BEGIN{FS=OFS=";"} {print $4,$2,$3,$1}'
neprazdne radky  :g/./ .!awk 'BEGIN{FS=OFS=";"} {print $4,$2,$3,$1}'

nebo vsechno a osetrit to v awku
:%!awk 'BEGIN{FS=OFS=";"} /./{print $4,$2,$3,$1; next} {print}'
gna
C / C++ › NULL
6. 6. 2017   #216596

Systémové includy se normálně píšou do pičatých závorek #include <stdlib.h>.

Program se nepíše do stdafx.cpp. Při použití předkompilovaných knihoven v MSVC musí každý .cpp soubor začínat includem "stdafx.h".

Ten nullptr znamená, že místo NULL budeš psát nullptr.

gna
C / C++ › Nefunguje ReadFile() pri čít…
6. 6. 2017   #216594

Při chybě ReadFile je zjistit kód chyby pomocí GetLastError.

gna
Příkazový řádek › Sestavení regulárního výrazu
6. 6. 2017   #216577

Nemám moc představu, co to má dělat, ale na jednoduché prohození bych to prohnal awkem: 

a;b;c;d
:%!awk 'BEGIN{FS=OFS=";"} {print $4,$2,$3,$1}'
d;b;c;a
gna
C / C++ › Generovaní náhodných čísel v C
6. 6. 2017   #216576

#3 Kenvelo

To je snad ještě blbější, než originál.

Funkce rand generuje pseudonáhodné hodnoty a ten generátor jde inicializovat funkcí srand. Aby nebyly generované hodnoty při každém spuštění programu stejné, tak se při každém spuštění programu rand inicializuje funkcí srand pokaždé s jinou hodnotou. Jen jednou, při spuštění programu, a typicky aktuálním časem.

Takže jediné co je tady potřeba udělat pro oddebilněni, je hodit jeden srand na začátek programu a z tohodle ty srand-y vycházet. Původní autor nejspíš jen nepochopil něčí doporučení před randem použít srand. Jak už KIIV napsal...

gna
C / C++ › OpenGL 3 Indexování a UV koo…
30. 5. 2017   #216459

Nevím, jestli by přebindování za běhu nějak šlo, ale "normální" řešení je prostě ten vertex nesdílet a mít ho několikrát s různými atributy.

gna
C / C++ › Algortimus funkce cos(x)
28. 5. 2017   #216410

#7 Kit
Pěkný.

gna
C / C++ › Algortimus funkce cos(x)
28. 5. 2017   #216402

O hlavu jí to neomlátí, protože to nejspíš je přesně to, co chtěl. Využití předchozích hodnot se samo nabízí a zase je to věc, nad kterou není potřeba přemýšlet. 

double mycos(double x)
{
	unsigned long f = 1;
	double sum = 0.0, p = 1.0;
	for(int i = 2, s = 1; i <= max2; i += 2, s = -s)
	{
		p *= x * x;
		f *= i * (i-1);
		sum += s * p / f;
	}
	return 1.0 - sum;
}
gna
Java › Programy, hry v jave
28. 5. 2017   #216395
gna
C / C++ › Algortimus funkce cos(x)
28. 5. 2017   #216394

Teda x^0 / 0! = 1 / 1.

gna
C / C++ › Algortimus funkce cos(x)
28. 5. 2017   #216393

Neumíš napsat cyklus na násobky dvou a otáčení znaménka?

Jinak teda i tu první jedničku můžeš napsat jako další kroky, pokud půjdeš od nuly: 0^0 / 0! = 1 / 1.
To otáčení znaménka můžeš udělat násobením 1 nebo -1 a to zase můžeš spočítat podle kroku cyklu.

Takže úplně obecně takhle:

sum = 0;
for (i = 0; i <= max; i++)
    sum += (pow(-1, i) * pow(x, i * 2)) / fac(i * 2);

Milionkrát řešená věc, kterou by nějak měl zvládnout každý.

gna
Mikrokontroléry › jak získat ukazatel na pole…
25. 5. 2017   #216304

#12 Jerry
Dokonce aj v tom k překladači, o kterém je řeč!   

gna
Pascal › excel?
25. 5. 2017   #216300

#19 ma ka
ahoj, má někdo vytvořený ten program?

To co jsem napsal je kompletní program. Data to čte ze standarního vstupu jako řádky čísel oddělených čárkou. Dělat to v Excelu je ptákovina. 

data.txt:
1,2,3,...
4,5,6,...
...

 

python3 program.py <data.txt
gna
Python › Python script exploit
25. 5. 2017   #216282

Pro více adres to stačí opakovaně spouštět. 

./generujadresy | while read IP; do ./skript "$IP"; done

Na timeout můžeš použít socket.settimeout, nebo select.select.

gna
Mikrokontroléry › jak získat ukazatel na pole…
25. 5. 2017   #216281

   

const char __code *p = pole;
gna
Mikrokontroléry › jak získat ukazatel na pole…
23. 5. 2017   #216233

   

__code const char *p;

Kdybys chtěl "univerzální" pointer, tak to bude něco jako __far. Ten ale zase budeš muset "downgradovat" (zkopírovat data) pro funkce, které ho neberou (RTL), nebo můžeš změnit paměťový model celého programu (což bude asi nejjednodušší, ale pro pár řádků kódu zbytečné a přijdeš o spoustu optimalizací).

EW8051 neznám, ale hledej tímhle směrem.

gna
Příkazový řádek › bash stahovaní souboru wget
23. 5. 2017   #216186

U té druhé varianty mám blbě uvozovky v tom řádku s wc. Buď escapni ty vnitřní, nebo vyhoď ty vnější

gna
Příkazový řádek › bash stahovaní souboru wget
23. 5. 2017   #216185

wget sám by se měl při přerušení spojení pokusit soubor dotáhnout a výsledek stahování signalizuje návratovám kódem. Takže můžeš testovat ten návratový kód.

Teoreticky může dojít k situaci, že wget nepozná, že stahování není kompletní (když třeba server neohlásí délku dat) a pak teda můžeš otestovat ještě obsah toho souboru. To už si odzkoušej, jestli to potřebuješ. 

SOUBOR=soubor.txt
POCET_POKUSU=10

for ((i=0; i<$POCET_POKUSU; i++)); do
	# wget ... "$SOUBOR"

	# $? je navratovy kod posledniho prikazu
	# -eq testuje na rovnost (equal)
	if [ $? -eq 0 ]; then
		# bez chyby, ukoncit cyklus
		break
	fi

	# pockat 60 sekund
	sleep 60
done

nebo

for ((i=0; i<$POCET_POKUSU; i++)); do
	# wget ... "$SOUBOR"

	# $() zachyti vystup prikazu
	# wc -l pocita pocet radku (wc -c pocet znaku)
	POCET_RADKU="$(wc -l <"$SOUBOR" 2>/dev/null)"

	# $(()) vezme tu hodnotu jako cislo, prazdnou nebo neciselnou hodnotu jako 0
	# -ge testuje na vetsi-nebo-rovno (greater or equal)
	if [ $((POCET_RADKU)) -ge 1 ]; then
		# splneno, ukoncit cyklus
		break
	fi

	# pockat 60 sekund
	sleep 60
done
gna
C / C++ › Jak testovat zaplnění obrazo…
20. 5. 2017   #216134

S těmi COLUMNS a LINES jsem se seknul. V bashi existují, ale programu se nepředávají. To ioctl bude nejčistší.

gna
C / C++ › Jak testovat zaplnění obrazo…
19. 5. 2017   #216111

Podmínka vypadá dobře, ale máš v tom souboru ten znak, že by se měl načíst?

Nicméně tohle nemáš dělat. Tím textovým souborem se pravděpodobně rozumí soubor, ve kterém jediný speciální znak bude odřádkování. Takže máš počítat pozici, na kterou vypisuješ a po zaplnění obrazovky počkat na pokyn k výpisu další strany a opakovat to.

Klidně do toho zapracuj i další řídící znaky, jako třeba ten form-feed a další. Pak pozor na to, že na Linuxu jde terminál ovládat výpisem řídících sekvencí (změna pozice kurzoru, scrollování, atd.).

Rozměry terminálu nejsnáze zjistíš pomocí getenv COLUMNS a LINES, které samozřejmě nemusí být nastavené. Případně pomocí ioctl TIOCGWINSZ. Změnu velikosti můžeš detekovat chytáním signálu SIGWINCH. A výstup programu taky vůbec nemusí být na terminál.

Pokud si s tím budeš chtít pořádně vyhrát, tak máš na nějakou dobu co dělat :-) Ale ty pokročilé věci asi zatím vynech a řeš jen ten jednoduchý texťák a rozměry třeba natvrdo.

gna
Python › Najdi lichá čísla dělitelná…
19. 5. 2017   #216109

Můžeš přerušit cyklus příkazem break.

for i in seznam:
    if i < 0:
        break
    ...
gna
Sítě › Pathping výpis
17. 5. 2017   #216091

Některé routery neodpovídají na ping, to je v pořádku.

gna
Assembler › Přepis krátkého kodu v jave…
16. 5. 2017   #216075

#2 Jerry
Nevšiml jsem si, že ty bys sem někdy napsal něco jiného, než chujoviny.

gna
Sítě › Pathping výpis
16. 5. 2017   #216070

A čemu na tom nerozumíš?

gna
Python › graficke rozhranie pre android
15. 5. 2017   #216039

Z chyby v ideálním případě bývá vidět o jakou chybu jde. Obrázek nefachčí.

Máš Python s Tk pro Android? Já nevím o tom, že by existoval, ale nesleduji to.

gna
C / C++ › (C++) Převod const unsigned…
15. 5. 2017   #216038

   

string returnData[rowCount]                            // tohle je pole stringů,
 = {(const char*)(sqlite3_column_text(statement, i))}; // ve kterém inicializuješ první string hodnotou sloupce

cout <<
        returnData[rowCount]                           // tímhle získáš string z pole
                                                       //   teda vlastně ne, když je ten index mimo rozsah toho pole
                            [columnCount]              // a tímhle znak z toho stringu
                                                       //   teda kdyby to byl platný index v platném stringu.
                                          << "\n";

Věci, které jsi dělal už stokrát! Nečaruj, přemýšlej. 

for (int i = 0; i < columnCount; i++) {
	cout << sqlite3_column_text(statement, i) << "\n";
}
gna
Java › Problém s načítáním do ze so…
13. 5. 2017   #216021

#6 Honza
A přesně proto se to dělá jedním readem, jak jsi to měl předtím.

gna
Pascal › Úprava programu
13. 5. 2017   #216014

Jsou to bodová svítidla, takže záleží jen na vzdálenosti, na úhlu nezáleží.

Kdybys do toho chtěla nějak zapojit strop, tak potřebuješ vzdálenost svítidel od stropu. A stejně jako pro podlahu spočítáš osvětlení pro strop. Definuješ nějakou světelnou odrazivost toho stropu a vzniknou ti tak další svítidla. Pak bys teda ještě mohla zapojit odraz od stolu a stěn a ... nevymýšlej kraviny.

A už minule ti Milan psal, že při zjišťování minima a maxima stolu porovnáváš hodnoty místnosti.

gna
Visual Basic › Visual Basic - Hledání v textu
13. 5. 2017   #216013
gna
Java › Java UDP Audio
12. 5. 2017   #216009

Takže jsi tam jen přidal pomalé zapisování a teď některá data propásneš. V čem bude problém? :-)

gna
C / C++ › Geometrický průměr v C++
12. 5. 2017   #216008

V tom výpisu procházíš jednotlivé řádky a jejich hodnoty. V čem se to tolik liší od toho jednorozměrného pole, se kterým to umíš?

A proč najednou indexuješ od 1 a kontrolujuješ hodnoty až dodatečně? Jsi to od někoho obšlehl, viď? :-)

gna
Pascal › Příklad v pascalu
10. 5. 2017   #215937

#12 Lolo24
Já to nemám na čem vyzkoušet, ale viděl bych to takhle: 

vykreslit prvni

readln; { pockat na enter }
ClearDvice; { smazat obrazovku }

vykreslit druhy

readln; { pockat na enter }
CloseGraph;
gna
Pascal › Příklad v pascalu
9. 5. 2017   #215933

Když smažeš načítání vstupu a smazání obrazovky, tak to nečeká na vstup a nesmaže obrazovku. Co jiného by to mělo udělat než vykreslit oba grafy hned a přes sebe? To je snad jasné.
(A nevím, jestli clrscr v grafickém režimu maže obrazovku. Spíš bych to viděl na clearviewport, nebo tak něco)

Netuším, co znamená, že to druhou část nepřečte.
Máš tam readln (načtení řádku, tedy všeho do enteru) a readkey (načtení jedné libovolné klávesy). Není možné, že jsi prostě něco z toho nezadala?

gna
Pascal › Příklad v pascalu
9. 5. 2017   #215930

jak mám zapsat výsledek, aby byly desetinné tečky pod sebou?

Zarovnání těch hodnot určují ta čísla za nimi

xs:15:3
ys:12:3
gna
Oracle › ako rozjet vlastnú databázu
8. 5. 2017   #215907

Ne, návodů na Oracle tolik není, protože to není hračka pro děti. Když tam ta data nemáš, tak jsi je nenaimportoval. Netuším co znamená, že se ti to otevře, ale Oracle Database není MySQL. Nainstaluj si MySQL a můžeš jet podle jejich turotiálů.

gna
C / C++ › C++ náhodné generování binár…
6. 5. 2017   #215904

Tak si to prokrokuj, nebo přidej výpisy.

Když jsi vyhodil ten srand, tak by se ti to mělo zanořit a jako count_nodes být x.

gna
Webové servery (Apache, IIS...), .htaccess › HTTPS na HTTP cez .htaccess…
5. 5. 2017   #215901

Když HTTPS přesměruješ na HTTP, které se zase přesměruje na HTTPS, tak si asi nepomůžeš.

Pokud to neumožňují vypnout, tak to nevypneš.

gna
C / C++ › (C++) Prvky pole do společné…
5. 5. 2017   #215896

#3 richard.zavodny
A připadá ti, že by taková věc měla mít problém s pamětí? Zkus si to v čistém programu.

Buď opravdu není volná paměť, což není moc pravděpodobné. Nebo jsi něco rozmrdal, což je mnohem pravděpodobnější, když si pořád hraješ s polema a nechápeš ani základní příkazy.

gna
MS SQL › Převod času na desetinné číslo
5. 5. 2017   #215894

#3 v24
Tak to mě nějak nenapadlo.. v sekci MS SQL :)

gna
Pascal › excel?
5. 5. 2017   #215879

A všimli jste si, že to všechno už Mircosoft napsal, že jo?

Nevím, co řešíte. Python:

import sys, collections, itertools, operator

data = []
for line in sys.stdin:
	data.append([int(i) for i in line.strip().split(",")])

counter = collections.defaultdict(int)
for row in data:
	for comb in itertools.combinations(row, 3):
		counter[comb] += 1

counter = sorted(counter.items(), key=operator.itemgetter(1), reverse=True)
print(counter[:3])
gna
MS SQL › Převod času na desetinné číslo
5. 5. 2017   #215877

   

datediff(second, 0, cas) / 60.0
gna
C / C++ › Funkcia for - oprava dvomi s…
4. 5. 2017   #215874

Pokud ti jde o to, aby to prošlo větším počtem iterací, tak je jedno, na které straně ten interval zvětšíš.

Na to se musíš ptát?

gna
Java › Vzdialenosť vrcholov v strome
4. 5. 2017   #215872

Taky nevím, kde se tam ta čísla berou.

gna
C / C++ › Serializace binárního stromu
4. 5. 2017   #215871

#1 nickan 

ifstream is("in.txt");
if (!is.is_open())
	chyba
if (!(is >> val))
	chyba
is.close();

ofstream os("out.txt");
if (!os.is_open())
	chyba
if (!(os << val << " "))
	chyba
os.close()

Do funkcí ty streamy předávej jako referenci.

gna
C / C++ › Serializace binárního stromu
4. 5. 2017   #215870

#4 Jerry
Je to ten strom, na který odkazuje. A VŮBEC NA TOM NEZÁLEŽÍ.

gna
C / C++ › Čas doby zápisu do souboru
4. 5. 2017   #215868

Když znáš time(), tak vyjeb ten clock(), který neměří uplynulý čas.

Jako ZAČÁTEK vypisuješ výsledek funkce DATUM(), která zjišťuje AKTUÁLNÍ čas a voláš ji na KONCI programu.

gna
PHP › Převod SRT na VTT titulky
4. 5. 2017   #215867

Pomocí preg_replace jde nahrazovat text podle regulárního výrazu.

Takže můžeš jednoduše udělat jakoby:

z  [00:00:08] , [550 --> 00:00:14] , [300]
na [^^^^^^^^] . [^^^^^^^^^^^^^^^^] . [^^^]

Co nejvíc tak, aby to nechytlo i něco jiného, třeba nějak takhle:

$SRT = "00:00:08,550 --> 00:00:14,300\ntady ne 00:00:08,550 --> 00:00:14,300\n\n00:00:08,550 --> 00:00:14,300";
$VTT = preg_replace('/^([\d:]{8}),(\d{3} --> [\d:]{8}),(\d{3})$/m', '$1.$2.$3', $SRT);
echo "WEBVTT\n\n$VTT";

Nebo udělat inteligentnější parser.

gna
Python › hledám programátora
4. 5. 2017   #215865

Už jsem na to předběžně koukal, ale teď na to nemám čas. Možná bude potřeba upravit ten ZBar a to bude náročnější (ale je napsaný hezky, půjde to). Pokud to někde nepřevezme, tak se vám během několika dní ozvu.

gna
C / C++ › Čas doby zápisu do souboru
4. 5. 2017   #215843

A kde v tom jde vyčíst, co přesně děláš?

gna
C / C++ › Úprava jednoduché hry v céčku
3. 5. 2017   #215838

Klávesy W a S jsou od začátku prohozené, protože jsem to napsal špatně. Prohoď to zpátky a nekopíruj, ale studuj.

Všude máš pole[R][S], ale ten zavináč testuješ na [S][R], takže jinde. Taky ho testuješ mimo ten blok pro pohyb, takže dokud budeš na @ tak se ti bude chaos pořád přehazovat.

Pokud neumíš používat krokování, tak si tam prostě přidej nějaké výpisy hodnot.

gna
JavaScript, AJAX, jQuery › JS problem content replace
3. 5. 2017   #215826

V podstatě to nahrazuje poslední "slovo" třemi tečkami dokud se to nevejde do požadované výšky.

Přestalo fungovat a nepomohlo je na hovno. Napiš co přesně to dělá a co je na tom špatně.

gna
Java › Vzdialenosť vrcholov v strome
2. 5. 2017   #215818

Pak bych ty vazby ještě od rootu pročistil ať jsou jednosměrné. Další práce pak bude jednodušší.

gna
Java › Vzdialenosť vrcholov v strome
2. 5. 2017   #215817

Pro každý uzel potřebuješ jeho vazby, takže třeba...

class Node
{
	List<Node> links = new ArrayList<Node>();
	
	public Node() {}
}

Pak je načteš a provážeš...

HashMap<Integer,Node> map = new HashMap<Integer,Node>();

while (sc.hasNext()) {
	int a = ...nextInt
	int b = ...nextInt

	Node nodeA = map.get(a);
	Node nodeB = map.get(b);
	
	if (nodeA == null) { nodeA = new Node(); map.put(a, nodeA); }
	if (nodeB == null) { nodeB = new Node(); map.put(b, nodeB); }
	
	nodeA.links.add(nodeB);
	nodeB.links.add(nodeA);
}
gna
Python › moze mi niekot vysvetlit ako…
2. 5. 2017   #215814

Ta moje verze po každé odpovědi napíše, jestli byla správně něbo špatně. Nevím, jak jsi to předělal.

gna
C / C++ › Přeskočení na druhý řádek v…
2. 5. 2017   #215813

#18 ORION206
Samozřejmě bys to mohl udělat i s tím tvým původním načítáním, že bys testoval hodnotu a/nebo počet těch tokenů a podle toho pokračoval.

gna
C / C++ › Přeskočení na druhý řádek v…
2. 5. 2017   #215812

#18 ORION206
operator>> načítá data ze streamu. operator! testuje stav streamu. příkaz continue přejde na další iteraci cyklu.

Takže když se z toho stringstreamu (řádku) nepodaří načíst těch 7 hodnot (kvůli množství nebo formátu dat), tak se zbytek těla cyklu přeskočí (čte se další řádek).

gna
C / C++ › Přeskočení na druhý řádek v…
2. 5. 2017   #215808

Nebo ještě jednodušeji prostě ignorovat všechno, co není datový řádek. Bez píčovin.

while (std::getline(ifs, line))
{
	std::istringstream ss(line);
	radek soucasnejRadek;

	if (!(ss
	         >> soucasnejRadek.x >> soucasnejRadek.y >> soucasnejRadek.z
	         >> soucasnejRadek.odrazivost
	         >> soucasnejRadek.r >> soucasnejRadek.g >> soucasnejRadek.b))
	{
		continue;
	}

	if (odrazivost[0] <= ...
gna
C / C++ › Přeskočení na druhý řádek v…
2. 5. 2017   #215806

Pokud je na prvním řádku jen jedna hodnota, tak je to počet řádků a chce ho přeskočit.

Je těžké to zapsat do ifu?

gna
C / C++ › Úprava jednoduché hry v céčku
2. 5. 2017   #215779

   

int zmenar = 0, zmenas = 0;

switch(znak) {
  case 'w': zmenar++; break;
  case 's': zmenar--; break;
  case 'd': zmenas++; break;
  case 'a': zmenas--; break;
}

if (chaos) {
  zmenar = -zmenar;
  zmenas = -zmenas;
}

int nover = pozicer + zmenar, noves = pozices + zmenas;

if (nover < 0 || nover >= MAX ||
    noves < 0 || noves >= MAX ||
    pole[nover][noves] == '#') {
  trestnebody++;
} else {
  pozicer = nover;
  pozices = noves;
}
gna
Python › Selenium - zjištění přítomno…
2. 5. 2017   #215778

   

try:
	driver.find...
except NoSuchElementException:
	...nenasel
gna
Python › moze mi niekot vysvetlit ako…
2. 5. 2017   #215777

input vrací textový řetězec, který konvertuju na int. Když v tom řetězci nebude číslo, tak ta konverze hodí chybu.

gna
C / C++ › Úprava jednoduché hry v céčku
2. 5. 2017   #215776

Ten zavináč testuješ mimo ten cyklus a testuješ hodnotu souřadnic místo obsahu pole.

A nepiš stejný kód 8krát, když se liší jen v jednom příkazu.

gna
Python › moze mi niekot vysvetlit ako…
1. 5. 2017   #215771

Na generování pseudonáhoných čísel můžeš použít modul random.

Zbytek už asi zvládneš, není moc co vysvětlovat.

import random

while True:
	a = random.randint(1,9)
	b = random.randint(1,9)
	vysledek = a * b
	spravne = False
	while not spravne:
		odpoved = int(input("%d * %d = " % (a,b)))
		spravne = odpoved == vysledek
		print("spravne" if spravne else "spatne")

Přidej tam ošetření nečíselné odpovědi a možnost ukončení a máš to.

gna
Java › Logika počítače
30. 4. 2017   #215767

Aha, já jsem myslel, že to máš ze školy a k tomuhle jste se nějak dopracovali.

Tak se v tom nejdříve zorientuj a pak bude navíc jen to, že ten tah neudělá hráč, ale program. Jak inteligentně už je na tobě, pro začátek bude stačit ten pseudonáhodný.

gna
Python › Pytho while tru, turtle
30. 4. 2017   #215764

   

while True:
    ...
    if podminka:
        zelva.color(barva)
    ...
gna
Java › Logika počítače
30. 4. 2017   #215763

Pomohl jako, že udělal za tebe? Máš tam všechno, co potřebuješ a zjevně tam není ani řádek od tebe. S čím přesně si nevíš rady?

Tak třeba náhodně vybírej minci a zkoušej ji posunout o náhodný počet polí, dokud nenajdeš platný tah. Random.nextInt

gna
Pascal › Program padá po spustení .ex…
27. 4. 2017   #215738

Na CD nejde normálně zapisovat.

gna
Pascal › Program padá po spustení .ex…
26. 4. 2017   #215735

Takže asi nekontroluješ, jestli se ten soubor podařilo otevřít. A nepovede se to asi proto, že se ho to pokouší otevřít i pro zápis.  

{$I-}
Assign(F, Name);
FileMode := fmOpenRead;
Reset(F);
{$I+}
if IOResult <> 0 then chyba...
gna
Pascal › Program padá po spustení .ex…
26. 4. 2017   #215732

Tak asi někde něco nekontroluješ a sletí to.

Typicky se runtime chyby vypisují na standardní výstup, takže když konzolovou aplikaci spustíš z konzole (příkazového řádku), aby se ti po skončení programu hned nezavřela, tak bys tam mohl něco vidět.

gna
Java › Java FX prosím o pomoc
26. 4. 2017   #215730

Když to přidáš do kódu, který máš u minulého dotazu, tak to bude vypadat nějak takhle:

...
public void aktualizujLabel() {
    LocalDate datum = zadavacDatumu.getValue();
    long pocet = getDaysToBirthDay(datum);
    label.setText("Narozky za: " + pocet);
}

private static long getDaysToBirthDay(LocalDate birthday) {
    ...
}
...
gna
Java › Java FX prosím o pomoc
26. 4. 2017   #215727

No někam si tam hoď tu funkci a pak ji použij, kde potřebuješ.

pocet = getDaysToBirthDay(datum);
gna
Java › Java FX prosím o pomoc
26. 4. 2017   #215719

V předchozím dotazu už nastavování textu Labelu máš. S čím si nevíš rady?

label.setText(...)

gna
MySQL › UPDATE SET - Aktualizace záz…
25. 4. 2017   #215701

   

UPDATE tabulka T1 
       JOIN tabulka T2 
         ON T1.opakovani_vliv = T2.id 
SET    T1.jmeno = T2.jmeno 
WHERE  T1.opakovani = 'ANO' 
       AND T2.opakovani = 'NE'; 
gna
Příkazový řádek › BASH shell: Jak změnit název…
21. 4. 2017   #215684

   

[[ $name == *text* ]] && name=$name.txt
gna
Python › Python třídění podle QR
17. 4. 2017   #215654

Děkuji, ale to není potřeba. Možná až budete mít někdy něco většího.

gna
Python › Python třídění podle QR
17. 4. 2017   #215652

   

a.png   -> 1\a.png       # kod 1
b.png   -> 2\b.png       # kod 2
cd.png  -> 3\cd.png      # kody 3,4
        -> 4\cd.png
efg.png -> 5\efg.png     # kody 5,6,7
        -> 6\efg.png
        -> 7\efg.png
a.png   -> 1\a (1).png   # kod 1
a.png   -> 1\a (2).png   # kod 1
gna
Python › Python třídění podle QR
17. 4. 2017   #215650

Takže takhle? 

import subprocess, os, re, locale, glob, shutil

encoding = locale.getdefaultlocale()[1]
zbarimg = "zbarimg"

def get_codes(filename):
	try:
		output = subprocess.check_output([zbarimg, "-q", filename])
		lines = output.strip().split(b'\n')
		lines = [line.decode(encoding) for line in lines]
		codes = [line.split(':',1)[1].strip() for line in lines]
		return codes if len(codes) else ["unreadable_code"]
	except:
		return ["unreadable_code"]

def make_path(code, filename):
	safecode = re.sub("[:/\\\\]", "_", code)
	fullpath = os.path.join(safecode, filename)

	if os.path.exists(fullpath):
		dirname = os.path.dirname(fullpath)
		filename,fileext = os.path.splitext(os.path.basename(fullpath))

		i = 0
		while os.path.exists(fullpath):
			i += 1
			fullpath = os.path.join(dirname, "%s (%d)%s" % (filename, i, fileext))

	return fullpath

image_files = glob.glob('*.JPG') + glob.glob('*.png')
print(image_files)

for image in image_files:
	print("======")
	print("file:", image)
	codes = get_codes(image)
	for code in codes:
		print("code:", code)
		dest = make_path(code, image)
		print("dest:", dest)
		os.makedirs(os.path.dirname(dest), exist_ok=True)
		shutil.copyfile(image, dest)
	os.remove(image)
gna
Python › Python třídění podle QR
17. 4. 2017   #215647

Tak nějak by to mělo fungovat.

Podle kódu to vytvoří složku a do ní přesune ten obrázek. Když je kódů víc než jeden, tak to vytváří podsložky. A pokud cílový soubor už existuje, tak se do názvu přidá unikátní číslo.

a.png   -> 1\a.png       # kod 1
b.png   -> 2\b.png       # kod 2
cd.png  -> 3\4\cd.png    # kody 3,4
efg.png -> 5\6\7\efg.png # kody 5,6,7
a.png   -> 1\a (1).png   # kod 1
a.png   -> 1\a (2).png   # kod 1
gna
.NET › Visual Basic
17. 4. 2017   #215644

Když v půlce dubna nedáš ani tu devítku (J = J * 2), tak nepotřebuješ poradit, ale prostě na to kašleš. Na vysvětlování všeho od začátku, nebo dělání cizích úkolů musí být sakra správná nálada.

Zkus sekci Inzerce a nabídnout odměnu.

gna
Python › Python třídění podle QR
17. 4. 2017   #215642

Do toho zbarimg si zase dej tu cestu k programu jak byla.

gna
Python › Python třídění podle QR
17. 4. 2017   #215641

   

import subprocess
import os
import re
import locale
import glob

encoding = locale.getdefaultlocale()[1]
zbarimg = "zbarimg"

def get_codes(filename):
	try:
		output = subprocess.check_output([zbarimg, "-q", filename])
		lines = output.strip().split(b'\n')
		lines = [line.decode(encoding) for line in lines]
		codes = [line.split(':',1)[1].strip() for line in lines]
		return codes if len(codes) else ["unreadable_code"]
	except:
		return ["unreadable_code"]

def make_path(codes, filename):
	safe_codes = [re.sub("[:/\\\\]", "_", code) for code in codes]
	fullpath = os.path.join(*safe_codes, filename)

	if os.path.exists(fullpath):
		dirname = os.path.dirname(fullpath)
		filename,fileext = os.path.splitext(os.path.basename(fullpath))

		i = 0
		while os.path.exists(fullpath):
			i += 1
			fullpath = os.path.join(dirname, "%s (%d)%s" % (filename, i, fileext))

	return fullpath

image_files = glob.glob('*.JPG') + glob.glob('*.png')
print(image_files)

for image in image_files:
	print("======")
	print("file:", image)
	codes = get_codes(image)
	print("codes:", codes)
	dest = make_path(codes, image)
	print("dest:", dest)
	os.makedirs(os.path.dirname(dest), exist_ok=True)
	os.rename(image, dest)
gna
C / C++ › ARP scanner pomocí raw BSD s…
17. 4. 2017   #215639

htons(ETH_P_ALL)

gna
C / C++ › ARP scanner pomocí raw BSD s…
17. 4. 2017   #215638

Řekl bych, že to vidíš dvakrát, protože ten odeslaný broadcast pak přijde i tobě.

Při vytváření socketu dej ETH_P_ALL nebo ETH_P_ARP místo IPPROTO_RAW.

gna
C / C++ › [VS 2015 C++] Resource Manag…
16. 4. 2017   #215628

To je C++/CLI. Jestli to chceš psát v .NETu, tak použij C#. A na takovou ptákovinu přece nepotřebuješ resources.

gna
MS SQL › Založení nového uživatele a…
16. 4. 2017   #215626

A jakou chybu?

Nevím proč ti nefunguje přidání do PATH, ale ještě se můžeš do toho adresáře přesunout:

> cd "C:\Program Files\MySQL\MySQL Server 5.7\bin\"
> mysql ...

Nebo to spouštět s celou cestou: 

"C:\Program Files\MySQL\MySQL Server 5.7\bin\mysql.exe" ...
gna
MS SQL › Založení nového uživatele a…
15. 4. 2017   #215620

Jo, ty chceš teprve psát ten příkaz pro spuštění? Ten napiš do příkazového řádku, nebo run dialogu, nebo parametrů zástupce, nebo kamkoliv jdou ty parametry zadat.

gna
MS SQL › Založení nového uživatele a…
15. 4. 2017   #215619

Těmi parametry říkáš, že se chceš připojit jako uživatel Kačka a na heslo, že se to má zeptat. Tak se to na něj ptá.

gna
MS SQL › Založení nového uživatele a…
15. 4. 2017   #215616

mysql -u Kačka -p

že ono mi to na začátku ani nenabídne se přihlásit na jiného uživatele

A to -u Kačka je tam asi na co?

gna
C / C++ › C - math.h (Unix) : kde jsou…
15. 4. 2017   #215611

A tuhle chybu by mělo vyřešit přesunutí libek (-l...) na konec.

gna
C / C++ › C - math.h (Unix) : kde jsou…
15. 4. 2017   #215610

Pokud ti to nehlásí chybu při kompilaci (implicitní deklarace), tak tu deklaraci naincludovanou máš.

 

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý