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

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

ただいまの
回答率

90.51%

  • PHP

    20395questions

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

  • Excel

    1541questions

    Excelは、マイクロソフト社が開発しているデータ集計や分析を行う表計算ソフトの一つです。文書作成や表計算、資料作成などの多彩な機能を備えており、統合パッケージであるMicrosoft Officeに含まれています。

Excel出力 ループ セルの位置

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 229

kirin311

score 42

また行き詰りましたので質問失礼します。

 前提・実現したいこと

・PHPでExcel操作のループで理想のセル配置。

■ 理想としては以下の通りです。

A B C D E F G
 ダミー1            ダミー2
名前1            名前2
 ダミー3            ダミー4
名前3            名前5

以降繰り返し~

理想通りにしたいです。

■■な機能を実装中に以下のエラーメッセージが発生しました。
エラーは、ありません。

 該当のソースコード

■ $listの中身
array (size=10)
0 => 
array (size=2)
'name' => string '名前1'
'address' => string 'ダミー1'
1 => 
array (size=2)
'name' => string '名前2'
'address' => string 'ダミー2'
2 => 
array (size=2)
'name' => string '名前3'
'address' => string 'ダミー3'
.
.
.
以降繰り返し
.
.
.

if ($is_dlbutton)
{ //DLボタンを押したら実行

    // テンプレートの読込

    $obj = PHPExcel_IOFactory::createReader('Excel5');
    $file = $obj->load("./excel.xls");
    $file->setActiveSheetIndex(0);
    $sheet = $file->getActiveSheet();
    $cnt = 0;
    while ($row = $list[$cnt])
    {
        if ($cnt % 2 == 0)
        {
            $sheet->setCellValue('A' . (8 * $cnt + 2) , $row["address"]); //住所
            $sheet->setCellValue('A' . (8 * $cnt + 5) , $row["name"]); //名前
        }
        else
        {
            $sheet->setCellValue('G' . (8 * $cnt + 2) , $row["address"]); //住所
            $sheet->setCellValue('G' . (8 * $cnt + 5) , $row["name"]); //名前
        }

        $cnt++;
    }

    header('Content-Type: application/force-download');
    header('Content-Disposition: attachment;  filename= mb_convert_encoding("excel.xls", "SJIS-win", "UTF-8")');
    $writer = PHPExcel_IOFactory::createWriter($sheet, "Excel5");
    $writer->save('php://output'); //出力開始
}

 試したこと

色々考えて出来たことは、該当のソースコードの内容に変えてしまってるので出せないです・・

■ 色々考えて出来たこと1

A B C D E F G
 ダミー1           
名前1            
 ダミー2           
名前2            
 ダミー3           
名前3            

■ 色々考えて出来たこと2

A B C D E F G
 ダミー1           
名前1            
            ダミー2
           名前2
 ダミー3           
名前3            

以上です、ヒントだけでも何らかのアドバイスを頂ければとても助かりますので是非ともよろしくお願いします。

修正後

papinianus様の回答により、理想通りにできましたので以下に修正いたしました。

 if ($is_dlbutton)
{ //DLボタンを押したら実行

 $obj = PHPExcel_IOFactory::createReader('Excel5');
    $file = $obj->load("./excel.xls");
    $file->setActiveSheetIndex(0);
    $sheet = $file->getActiveSheet();
    $cnt = 0;

    // テンプレートの読込
    $obj = PHPExcel_IOFactory::createReader('Excel5');
    $file = $obj->load("./excel.xls");
    $file->setActiveSheetIndex(0);
    $sheet = $file->getActiveSheet();
    $cnt = 0;

  while ($row = $list[$cnt])
      $param1 = floor($cnt/2);//2で割って小数点以下を切り捨てる
      if($cnt % 2 == 0){
        //0*7パターン
        $sheet->setCellValue('A' . ($param1*8+1), $row["address"]); //住所
        $sheet->setCellValue('A' . ($param1*8+2) , $row["name"]); //名前
      }else{
        //1*7パターン
        $sheet->setCellValue('G' . ($param1*8+1), $row["address"]); //住所
        $sheet->setCellValue('G' . ($param1*8+2) , $row["name"]); //名前
      }
        $cnt++;
    }

    header('Content-Type: application/force-download');
    header('Content-Disposition: attachment;  filename= mb_convert_encoding("excel.xls", "SJIS-win", "UTF-8")');
    $writer = PHPExcel_IOFactory::createWriter($sheet, "Excel5");
    $writer->save('php://output'); //出力開始 
 }


ただ、非推奨とのことなのでPhpSpreadsheeでこちらの考え方をもとに作らせて頂きます。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • mts10806

    2018/06/14 09:40

    PHPExcelは非推奨となっています。後継である後継PhpSpreadsheetを使ってください。 https://qiita.com/suin/items/7a8d0979b7675d6fd05b

    キャンセル

  • kirin311

    2018/06/14 09:53

    回答ありがとうございます。レンタルサーバーにアップロードという形でPHPを確認しており、ローカルにはphp自体をインストールしておらず、composerも使ってないので後継について十二分に調べて導入させていただきます。

    キャンセル

回答 1

checkベストアンサー

0

ヒント的な回答を。

$listの各要素(要素自身も連想配列ですが)について、以下のことを考えると、行と列が計算できると思います。

  • $listのインデックス(n番目)というのを、2で割った商に丸める
    (0は0、1は0、2は1、3は1、4は2、5は2、といった感じ)
  • 出力行を3行セットと見る。で、3に↑の丸めた値をかける

この2つで、住所を出すべき行数が求まる。名前はこれにプラス1をする

  • $listのインデックス(n番目)というのを、2で割った余りを考える。これを7倍すれば、列が求まる
    (0*7 と1*7の2パターンになる)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/06/14 09:55

    回答ありがとうございます。こちらをもとに考えさせていただきます。

    キャンセル

  • 2018/06/14 12:14

    papinianus様の考えのもと理想通りにできましたのでベストアンサーにさせていただきます。

    キャンセル

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

  • ただいまの回答率 90.51%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 受付中

    PHPExcelエラーの明確な原因

    PHPExcelでテンプレートを読み込み、データを出力するように作ったのですが テンプレートに予めオートフィルタを設定しておくと下記エラーが出ることがわかりました。 手作業

  • 解決済

    PHPExcelでexcelへの書き込み

    お世話になっております。 PHPExcelによるエクセルDLについてお尋ねです。 前提・実現したいこと PHPExcelでテンプレート読み込み ↓ DBから取得したデ

  • 解決済

    PHPExcelで斜めの罫線を引きたい

    前提・実現したいこと PHPExcelを使ってセルに右上がりの罫線を引きたいと考えています。 エラー等は出ないのですが引くことができませんでした。 引き方が間違えているのでし

  • 解決済

    カンマ区切りのデータの重複する要素とその値を合計したい

    閲覧ありがとうございます。 カンマ区切りのデータの重複する要素とその値を合計したいのですが、どのようにすればよいのでしょうか? とても大きなデータなので、excelでは開け

  • 受付中

    エクセル関数で数字のみを塊で抜き出したい

    前提・実現したいこと A列:数字(半角・全角を含む1文字以上)+文字列(漢字・半角全角英字等)から ※想定パターン(A1~A3セルの3パターン) B列:A列右から最初の数字(半角・

  • 解決済

    Excel VBA 特定範囲の重複している列に空白を設定する

    お世話になっております EXCELのVBAや関数を使用し、下記の様な表を編集したいと思っております。 置換前 グループ 項目1* 項目2 項目3 項目X 項目Y

  • 受付中

    Excelで分単位でバラバラに記録されたデータから将来予測

    前提・実現したいこと 艦これの支援ソフト「航海日誌拡張版」から出力される資源ログのデータをもとに、指定日を初日として、このまま遠征等を続けたらいかほど資源が獲得できるかを将来予測す

  • 解決済

    Excel重複データのチェック

    エクセルで特定の列のセルにデータを入力した時に、同じ列内に重複データがある場合、 重複データの行の色を変えて、更に可能であれば、アラートで「●個目の重複データです」と表示させたいの

同じタグがついた質問を見る

  • PHP

    20395questions

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

  • Excel

    1541questions

    Excelは、マイクロソフト社が開発しているデータ集計や分析を行う表計算ソフトの一つです。文書作成や表計算、資料作成などの多彩な機能を備えており、統合パッケージであるMicrosoft Officeに含まれています。