Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP]edycja konkretnej podpisanej lini w pliku, j.w.
mount
post
Post #1





Grupa: Zarejestrowani
Postów: 28
Pomógł: 0
Dołączył: 18.07.2009

Ostrzeżenie: (0%)
-----


niestety brakuje mi wiedzy na ten temat, a szukając w google brakuje pomysłów jak to skleić w całość...

mam plik tekstowy "users.txt"

  1. "dane[0]" "dane[1]" "dane[2]" "dane[3]" ; $userid


każda linia zawiera dane oddzielone spacjami w cudzysłowach, a linia jest zakończona "; $userid"
gdzie userid ma być identyfikatorem dla danej linii z danymi


proszę o podpowiedź jak edytować linię z konkretnym userid na końcu, czyli znajduje
linię z konkretnym "; $userid", zastępuje całą linią nową linią?

pozdrawiam

Ten post edytował mount 18.10.2010, 16:43:04
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 4)
markonix
post
Post #2





Grupa: Zarejestrowani
Postów: 2 707
Pomógł: 290
Dołączył: 16.12.2008
Skąd: Śląsk

Ostrzeżenie: (0%)
-----


Hm, może tak:
- pobrać plik do zmiennej
- przetworzyć zawartość funkcją explode (entery), albo wyrażeniami regularnymi
- każdą linie masz w tablicy
- jeżeli $userid to nie kolejne liczby od 0 wzwyż (zbyt proste) to tablice by trzeba było drugi raz przetworzyć: z każdego wiersza wyciągnąć sam numer (wyrażenia regularne) i przypisać to do nowej tablicy.

tablica 0 => tablica2[userid] = tresc wiersza
tablica 1 => tablica2[userid] = tresc wiersza
tablica 2 => tablica2[userid] = tresc wiersza

Potem jeśli chcesz usunąć jakiś wiersz na podstawie userid to po prostu:
tablica2[$userid] = nowa tresc;
Jeśli zapis do pliku to zawartość tablicy do zmiennej i nadpisanie pliku.

Na pewno coś lepszego da się z tym zrobić ale sposób to jest..

Ten post edytował markonix 18.10.2010, 23:00:15
Go to the top of the page
+Quote Post
mount
post
Post #3





Grupa: Zarejestrowani
Postów: 28
Pomógł: 0
Dołączył: 18.07.2009

Ostrzeżenie: (0%)
-----


  1. $nazwa = "users.ini";
  2. $plik = fopen($nazwa,"r");
  3.  
  4. $pobrany_plik = fread($plik,filesize($nazwa));
  5. fclose($plik);
  6.  
  7. $dane = explode("\n", $pobrany_plik);


poszukam jak to załadować do tablicy, czekam jeszcze na jakieś propozycje
dziękuje (IMG:style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post
markonix
post
Post #4





Grupa: Zarejestrowani
Postów: 2 707
Pomógł: 290
Dołączył: 16.12.2008
Skąd: Śląsk

Ostrzeżenie: (0%)
-----


Cytat(mount @ 18.10.2010, 21:40:21 ) *
poszukam jak to załadować do tablicy


Użyłeś funkcji, która to robi za Ciebie tylko z indeksami o które nie będziesz mógł się oprzeć.
Dlatego gdy już użyjesz explode to wykonaj pętle foreach na tej tablicy i stwórz nową tablice.
Przy każdym obrocie musisz wykonać tylko proste wyrażenie regularne wyciągające userid.
Potem tylko $nowaTablica[$userid] = $value;

Ten post edytował markonix 18.10.2010, 22:58:11
Go to the top of the page
+Quote Post
mount
post
Post #5





Grupa: Zarejestrowani
Postów: 28
Pomógł: 0
Dołączył: 18.07.2009

Ostrzeżenie: (0%)
-----


zrobiłem to trochę prościej (IMG:style_emoticons/default/smile.gif)

  1. for ($linia = 0; $linia < count($dane); $linia++) {
  2. if (strpos($dane[$linia], $uid) > 0) {
  3. echo ("znaleziono na linii $linia. <br>");
  4. }
  5. }
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 26.09.2025 - 14:33