Экспорт таблицы sqlite с использованием php - PullRequest
2 голосов
/ 21 октября 2010

Я только начинаю работать с PHP, и мне нужно экспортировать таблицу из моей базы данных sqlite в CSV или, в идеале, в XLS. Я нашел пример с использованием MySQL, но я не могу преобразовать его для работы с SQLite.

Вот что у меня есть:

<?php
$db     = new PDO('sqlite:../ccm.sqlite');
$query  = $db->query('SELECT * FROM Emails');
$export = sqlite_query ($query);
$fields = sqlite_num_fields ( $export );

for ( $i = 0; $i < $fields; $i++ ){
    $header .= sqlite_field_name( $export , $i ) . "\t";
}

while( $row = sqlite_fetch_row( $export ) ){
//sqlite_fetch_row doesnt actually exist...
    $line = '';
    foreach( $row as $value ){                                            
        if ( ( !isset( $value ) ) || ( $value == "" ) ){
            $value = "\t";
        }else{
            $value = str_replace( '"' , '""' , $value );
            $value = '"' . $value . '"' . "\t";
        }
        $line .= $value;
    }
    $data .= trim( $line ) . "\n";
}
$data = str_replace( "\r" , "" , $data );

if ( $data == "" ){
    $data = "\n(0) Records Found!\n";                        
}

header("Content-type: application/octet-stream");
header("Content-Disposition: attachment; filename=emails.xls");
header("Pragma: no-cache");
header("Expires: 0");
print "$header\n$data";
?>

Может кто-нибудь помочь мне с этим? или если есть более простой способ, который был бы великолепен. Приветствия

Ответы [ 4 ]

2 голосов
/ 21 октября 2010

Вы смешиваете методы PDO с функциями sqlite_ *;попробуйте использовать одно или другое:

$db = new PDO("sqlite:../ccm.sqlite");
$query = $db->query("select * from emails");
$first_row = true;
while ($row = $query->fetch(PDO::FETCH_ASSOC))
{
  if ($first_row)
  {
    // I'm not sure how to get the field names using a PDO method but
    // we can use the first row's (or any row's) key values as these
    // are the field names.
    $first_row = false;
    $number_of_fields = count($row);
    $field_names = array_keys($row);
    $first_field_name = $field_names[0];
  }
  // do stuff here with the row
  print_r($row);
}

или

$db = sqlite_open("../cmm.sqlite");
$query = sqlite_query($db, "select * from emails");
$number_of_fields = sqlite_num_fields($query);
$first_field_name = sqlite_field_name($query, 0);
while ($row = sqlite_fetch_array($query))
{
    // do stuff here with the row.
    print_r($row);
}

Я не уверен на 100%, но я думаю, что PDO работает с базами данных sqlite3, а функции sqlite_ * работают с базами данных sqlite2.

2 голосов
/ 06 августа 2013

Я улучшил ответ Стейси и подумал поделиться им здесь. Я добавил заголовки, чтобы браузер загружал вывод в виде файла CSV.

<?
// Set headers to make the browser download the results as a csv file
header("Content-type: text/csv");
header("Content-Disposition: attachment; filename=filename.csv");
header("Pragma: no-cache");
header("Expires: 0");

// Connect to DB
$conn = new PDO('sqlite:db_name.db');

// Query
$query = $conn->query("SELECT * FROM some_table");

// Fetch the first row
$row = $query->fetch(PDO::FETCH_ASSOC);

// If no results are found, echo a message and stop
if ($row == false){
    echo "No results";
    exit;
}

// Print the titles using the first line
print_titles($row);
// Iterate over the results and print each one in a line
while ($row != false) {
    // Print the line
  echo implode(array_values($row), ",") . "\n";
    // Fetch the next line
  $row = $query->fetch(PDO::FETCH_ASSOC);
}

// Prints the column names
function print_titles($row){
    echo implode(array_keys($row), ",") . "\n";
}
1 голос
/ 03 сентября 2014

Если вам нужно отправить файл CSV непосредственно в браузер, без записи во внешний файл, вы можете открыть вывод и использовать для него fputcsv.

    <?php
    $out = fopen('php://output', 'w');
// print column header
    fputcsv($out, array_keys($row)));
//or print content directly
    fputcsv($out, array_values($row)));
    fclose($out);
    ?>
1 голос
/ 21 октября 2010

Если мне нужно быстро получить данные из базы данных sqlite3 как файлы CSV, я использую CLI sqlite3:

$ sqlite3 ccm.sqlite
sqlite> .mode csv
sqlite> .output emails.csv
sqlite> .headers on
sqlite> select * from emails
sqlite> .output stdout
sqlite> .quit
$ cat emails.csv

Это запускает CLI sqlite3, открывающий базу данных ccm.sqlite, устанавливает режим выводав csv (формат операторов select), устанавливает вывод в файл с именем emails.csv, включает выбор заголовков столбцов (необязательно), выбирает все данные в таблице электронных писем, устанавливает стандартный вывод (закрытие файла emails.csv)), выходит из CLI и проверяет вывод, отправляя его стандартному выходу.

Существуют и другие форматы, которые вы можете вывести, введите .help в командной строке sqlite3 CLI:

.mode MODE ?TABLE?     Set output mode where MODE is one of:
                         csv      Comma-separated values
                         column   Left-aligned columns.  (See .width)
                         html     HTML <table> code
                         insert   SQL insert statements for TABLE
                         line     One value per line
                         list     Values delimited by .separator string
                         tabs     Tab-separated values
                         tcl      TCL list elements
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...