155GIT1 / 4. cvičení: Porovnání verzí

Z GeoWikiCZ
Přejít na: navigace, hledání
m (Formátování dat obecně)
m (Formátované čtení matice)
Řádek 106: Řádek 106:
 
type m.txt  
 
type m.txt  
 
# znovunačtení do dimenze [5x5]
 
# znovunačtení do dimenze [5x5]
 +
f = fopen('m.txt', 'r');
 
B = fscanf(f, '%f', [5, inf])
 
B = fscanf(f, '%f', [5, inf])
 
#
 
#
Řádek 113: Řádek 114:
 
# přeskakování položek
 
# přeskakování položek
 
s = sscanf('10.2 5.222 4.2', '%f %*f %f')
 
s = sscanf('10.2 5.222 4.2', '%f %*f %f')
 +
fclose(f);
 
</source>
 
</source>
  

Verze z 16. 3. 2016, 13:21

předchozí cvičenístránky předmětudalší cvičení

Čtení a zápis textových souborů

Náplň cvičení

  1. opakování - workspace
  2. zápis matice do textového souboru
  3. formátování výstupu
  4. čtení matice z textového souboru

Ukázky

Formátovaný zápis matice

A = rand(3,4) * 10;
f = fopen('a.txt', 'w');
fprintf(f, '%f %f %f %f\n', A);
fclose(f); # zápis je proveden až při uzavření souboru
type a.txt 
5.272319 6.032164 4.710683 3.489846
3.702292 9.547577 9.105915 4.923848
6.948680 8.851383 7.628851 6.733618
#
# změna dimenze matice při zápisu
f = fopen('a1.txt', 'w');
fprintf(f, '%f %f %f\n', A);
fclose(f);
type a1.txt 
5.272319 6.032164 4.710683
3.489846 3.702292 9.547577
9.105915 4.923848 6.948680
8.851383 7.628851 6.733618
#
# změna formátování
f = fopen('a2.txt', 'w');
fprintf(f, '%.1f %.1f %.1f %.1f\n', A);
fclose(f);
type a2.txt
5.3 6.0 4.7 3.5
3.7 9.5 9.1 4.9
6.9 8.9 7.6 6.7
#
# zápis dat do již existujícího souboru
f = fopen('a.txt', 'a');
fprintf(f, '%f %f %f %f\n', A(1,:));
fclose(f);
type a.txt
5.272319 6.032164 4.710683 3.489846
3.702292 9.547577 9.105915 4.923848
6.948680 8.851383 7.628851 6.733618
5.272319 3.489846 9.105915 8.851383

Formátování dat obecně

fprintf('%s: %i\n', 'moje nahodne cislo (1 az 100)', randi(100))
moje nahodne cislo (1 az 100): 31
#
# uložení do řetězce
r = sprintf('%s: %i\n', 'moje nahodne cislo (1 az 100)', randi(100))
class(r)
ans = char
#
# příklad formátování dvou řádkových vektorů 
a = 1:10
fprintf('a: %.2d -> a^2: %.3d\n', [a; a.^2])
a: 01 -> a^2: 001
a: 02 -> a^2: 004
a: 03 -> a^2: 009
a: 04 -> a^2: 016
a: 05 -> a^2: 025
a: 06 -> a^2: 036
a: 07 -> a^2: 049
a: 08 -> a^2: 064
a: 09 -> a^2: 081
a: 10 -> a^2: 100
#
fprintf('a: %2d -> a^2: %3d\n', [a; a.^2])
a:  1 -> a^2:   1
a:  2 -> a^2:   4
a:  3 -> a^2:   9
a:  4 -> a^2:  16
a:  5 -> a^2:  25
a:  6 -> a^2:  36
a:  7 -> a^2:  49
a:  8 -> a^2:  64
a:  9 -> a^2:  81
a: 10 -> a^2: 100

Formátované čtení matice

A = magic(5)
f = fopen('m.txt', 'w');
# uložení jako sloupcový vektor
fprintf(f, '%f\n', A);
fclose(f);
type m.txt 
# znovunačtení do dimenze [5x5]
f = fopen('m.txt', 'r');
B = fscanf(f, '%f', [5, inf])
#
# čtení z řetězce
s = sscanf('10.2 5.222', '%f %f')
#
# přeskakování položek
s = sscanf('10.2 5.222 4.2', '%f %*f %f')
fclose(f);

Změna polohy kurzoru v souboru

f = fopen('s.txt', 'w+')
fprintf(f, '%f\n', [1 2; 3 4]) 
fclose(f)
type s.txt
1.000000
3.000000
2.000000
4.000000
#
f = fopen('s.txt')
a = fscanf(f, '%f', [1, inf])
b = fscanf(f, '%f', [2, inf])
fseek(f, 0)
b = fscanf(f, '%f', [2, inf])

Úlohy