(PHP 4, PHP 5, PHP 7, PHP 8)
fwrite — Escrita binary-safe em arquivos
fwrite() grava o conteúdo de data
no ponteiro de arquivo informado em stream
.
fwrite() retorna o número de bytes escritos, ou false
em caso de falha.
fwrite() emite um E_WARNING
em caso falhas.
Versão | Descrição |
---|---|
8.0.0 | length pode ser null. |
Exemplo #1 Exemplo de fwrite()
<?php
$filename = 'test.txt';
$somecontent = "Acrescente isso no arquivo\n";
// Vamos garantir que o arquivo existe e pode ser escrito
if (is_writable($filename)) {
// Nesse exemplo estamos abrindo o $filename em modo append.
Nota:
Escrever em um fluxo de rede pode acabar antes de toda a string ser transmitida. O retorno de fwrite() precisa ser inspecionado:
<?php
function fwrite_stream($fp, $string) {
for ($written = 0; $written < strlen($string); $written += $fwrite) {
$fwrite = fwrite($fp, substr($string, $written));
if ($fwrite === false) {
return $written;
}
}
return $written;
}
?>
Nota:
Em sistemas que diferenciam entre arquivos binários e texto (por exemplo Windows) o arquivo tem que ser aberto com 'b' incluído no parâmetro 'mode' na fopen().
Nota:
Se o
stream
foi aberto com fopen() em modo de adição, escritas com fwrite() são atômicas (a não ser que o tamanho dadata
exceda o tamanho de bloco do sistema de arquivos, em algumas plataformas, e contanto que o arquivo esteja em um sistema de arquivos local). Sendo assim, não há necessidade de bloquear um recurso com flock() antes de chamar fwrite(); todos os dados serão escritos sem interrupção.
Nota:
Se escrever duas vezes no ponteiro do arquivo, então a informação será adicionado ao final do contéudo do arquivo:
<?php
$fp = fopen('data.txt', 'w');
fwrite($fp, '1');
fwrite($fp, '23');
fclose($fp);
// O conteúdo de 'data.txt' é 123, e não 23
?>