質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

2回答

2071閲覧

phpのメモリ容量について

vike

総合スコア17

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2017/07/28 02:16

phpのメモリの容量について
今csvのデータを読み込み整形するようなものを作っていたのですが
Allowed memory size of 536870912 bytes exhausted
のようなエラーが出てしまいました。

php.iniのmemory_limitを変更すれば表示はできたのですが、かなりの容量を
使ってしまったので、プログラム側を変更したいのですが、どの場所を変更すれば良いかがわかりません。

php

1setlocale(LC_ALL, 'ja_JP.UTF-8'); 2 3$file = 's105.csv'; 4$data = file_get_contents($file); 5$temp = tmpfile(); 6$csv = array(); 7 8fwrite($temp, $data); 9rewind($temp); 10 11 12$f = fopen("sample.csv", "w"); 13 14 15$delete_column = array(4,5,6,7,9,8); 16 17while (($data = fgetcsv($temp, 0, ",")) !== FALSE) { 18 19 20 foreach($delete_column as $col_num){ 21 22 unset($data[$col_num]); 23 } 24 $data = array_filter($data, 'strlen'); 25 26 27 $data = array_values($data); 28 29 30 $csv[] = $data; 31} 32 33 34if ( $f ) { 35 36 foreach($csv as $line){ 37 38 39 fputcsv($f, $line); 40 41 } 42} 43 44fclose($f); 45 46print_r($csv); 47 48fclose($temp); 49 50 51

回答よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

$file->setFlags( SplFileObject::READ_CSV | SplFileObject::SKIP_EMPTY | SplFileObject::READ_AHEAD );

こういったSplFileObjectを使用してみてはいかがでしょう。
1行ずつ読み込んでくれるので、
処理は多少遅くはなりますがメモリの使用量はかなり減ります。

https://kantaro-cgi.com/blog/php/super-csv-loader.html

こちらのページに詳しくありますので試してみてください。

投稿2020/05/25 04:13

hk206

総合スコア20

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ini_set('memory_limit', '256M');

これを追加するではうまくいかないでしょうか?

マニュアル

PHPのメモリの上限を変更する

投稿2017/07/28 02:36

編集2017/07/28 02:39
balaenoptera

総合スコア222

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問