2013年1月28日 星期一

PHP 讀 csv 檔:fgetcsv()

用 PHP 讀 csv 檔,沒想到還有專用的函式 XD

用法是先 fopen() ,然後再用 fgetcsv() 一行一行抓進來,每行都會存成一個 array 。
其中第二個 argument 是最大字串長度,在 PHP 5 裡面可以不給或是填 0 表示無上限,不過會比較慢。
每行的欄位數量可以不同沒有關係,用 count() 去算一下就好。
另外由於是一行一行處理,連 foreach 都省了 XD

範例程式如下:

<?php
$row = 1;
if (($handle = fopen("test.csv", "r")) !== FALSE) {
    while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
        $num = count($data);
        echo "<p> $num fields in line $row: <br /></p>\n";
        $row++;
        for ($c=0; $c < $num; $c++) {
            echo $data[$c] . "<br />\n";
        }
    }
    fclose($handle);
}
?>
Reference: http://php.net/manual/en/function.fgetcsv.php

2013年1月22日 星期二

PHP foreach 與二維陣列

本來用了這樣的方式處理:

<?php
$array = [
    [1, 2],
    [3, 4],
];

foreach ($array as list($a, $b)) {
    // $a contains the first element of the nested array,
    // and $b contains the second element.
    echo "A: $a; B: $b\n";
}
?>

想說奇怪怎麼跑出錯誤訊息,後來才發現這要 PHP 5.5 以上才有,我灌的是 PHP 5.4.10...

沒辦法只好乖乖用普通方法了:

<?php
$array = [
    [1, 2],
    [3, 4],
];

foreach ($array as $vals)) {
    echo "A: $vals[0]; B: $vals[1]\n";
}
?>

雖然本來也有點想用 $array[0][0], $array[0][1], $array[1][0], $array[1][1] 硬幹不過還是算了XD

2013年1月14日 星期一

perror - 印出系統錯誤訊息


gdb 用不習慣,土炮 printf/cout 搭配用好夥伴;至少不用整天 cout << "fuck" 這樣 XD

valgrind 快速上手

valgrind 是檢查記憶體用的小程式,因為是快速上手就不介紹了,可以自己 google 一下介紹很多 XD