Rumah >pembangunan bahagian belakang >Tutorial Python >Menggunakan Python untuk menghuraikan data spreadsheet
Pemprosesan data spreadsheet yang biasa dalam organisasi besar dan perusahaan dan mengimportnya ke dalam aplikasi web adalah satu cabaran bagi banyak pemaju. Artikel ini akan meneroka cara untuk memproses dan menghuraikan data tersebut menggunakan Python, termasuk membaca dan menulis ke XLSX, CSV, dan versi spreadsheet yang lebih lama.
Mata utama:
Asas Spreadsheets:
Fail spreadsheet adalah koleksi pelbagai lembaran kerja, setiap lembaran kerja adalah koleksi sel data yang diatur dalam grid, sama dengan jadual. Dalam lembaran kerja, sel data dikenalpasti oleh nombor baris dan nombor lajurnya.
Tetapan Alam Sekitar Python:
Kami akan menggunakan Python 3 untuk membaca dan menulis kepada spreadsheet. Untuk membaca dan menulis fail XLSX, anda perlu memasang modul PANDAS. Anda boleh menggunakan pemasang python seperti pip atau easy_install untuk dipasang. Pandas menggunakan modul OpenPyxl untuk membaca fail spreadsheet baru (.xlsx) dan menggunakan modul XLRD untuk membaca spreadsheet lama (.xls file). Apabila panda dipasang, kedua -dua modul (OpenPyxl dan XLRD) akan dipasang sebagai kebergantungan:
<code class="language-bash">pip3 install pandas</code>Untuk membaca dan menulis fail CSV, modul CSV diperlukan, yang dipasang di Python. Fail CSV juga boleh dibaca melalui panda.
Baca spreadsheet:
Jika anda ingin menghuraikan data dalam fail, anda perlu melaksanakan operasi berikut dalam urutan berikut:
<code class="language-bash">pip3 install pandas</code>
Pandas membaca spreadsheet sebagai meja dan menyimpannya sebagai DataFrame Pandas.
Jika fail mengandungi aksara bukan ascii, ia harus dibuka dalam format unicode:
<code class="language-python">import pandas as pd workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx') workbook.head()</code>
Jika spreadsheet sangat besar, anda boleh menambah parameter use_cols
, yang hanya memuat lajur tertentu ke dalam bingkai data. Sebagai contoh, parameter berikut hanya akan membaca lima lajur pertama:
<code class="language-python">import sys workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx', encoding=sys.getfilesystemencoding())</code>
Di samping itu, anda boleh menggunakan parameter nrows
dan skiprows
untuk hanya membaca sejumlah baris, atau mengabaikan sejumlah baris tertentu pada mulanya.
Anda boleh menggunakan parameter sheet_name
untuk memilih lembaran kerja tertentu dari spreadsheet. Secara lalai, fungsi read_excel()
mengasingkan lembaran kerja pertama dalam fail. Nama lembaran kerja boleh disediakan sebagai rentetan, atau indeks lembaran kerja (bermula dari 0):
<code class="language-python">workbook = pd.read_excel('~/Desktop/import-export-data.xlsx', usecols = 'A:E') workbook.head()</code>
Pelbagai lembaran kerja juga boleh dipilih sebagai penyimpanan kamus untuk bingkai data panda dengan lulus senarai ke sheet_name
parameter:
<code class="language-python"># 读取名为'Sheet1'的工作表 worksheet = pd.read_excel('sample-xlsx-file-for-testing.xlsx', sheet_name = 'Sheet1') # 读取文件中的第一个工作表 worksheet = pd.read_excel('sample-xlsx-file-for-testing.xlsx', sheet_name = 0)</code>
Setelah memilih lembaran kerja ke bingkai data, anda boleh mengekstrak nilai sel data tertentu dengan menanyakan bingkai data Pandas:
<code class="language-python"># 读取前两个工作表和名为'Sheet 3'的工作表 worksheets = pd.read_excel('~/Desktop/import-export-data.xlsx', sheet_name = [0, 1, 'Sheet 3'])</code>Kaedah
.iloc()
membantu mencari nilai berdasarkan kedudukan indeks. Dalam kod di atas, .iloc()
cari nilai kedudukan indeks ke -0. Begitu juga, kaedah .loc()
boleh digunakan untuk mencari nilai menggunakan tag. Sebagai contoh, jika anda lulus parameter 0 ke kaedah .loc()
, ia akan mencari tag 0 dalam indeks:
<code class="language-python">import pandas as pd workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx') # 打印'Product'列的第一个值 print(workbook['Product'].iloc[0]) => Carretera</code>
Selepas memuatkan dataset ke dalam data data, anda boleh menanyakan dataset menggunakan fungsi terbina dalam dalam panda.
Buat spreadsheet:
Proses membuat lembaran kerja adalah serupa dengan bahagian sebelumnya.
Untuk membuat fail baru, anda terlebih dahulu memerlukan bingkai data. Mari kita buat semula jadual demo pada permulaan artikel:
<code class="language-python">print(workbook['Product'].loc[0]) => Carretera</code>
Anda kemudian boleh membuat fail spreadsheet baru dengan memanggil fungsi to_excel()
ke bingkai data dan tentukan nama fail yang harus disimpan:
<code class="language-python">import pandas as pd name = ['John', 'Mary', 'Sherlock'] age = [11, 12, 13] df = pd.DataFrame({ 'Name': name, 'Age': age }) df.index.name = 'ID'</code>
juga boleh menggunakan fungsi read_excel()
untuk membuka fail yang sama.
Bingkai data boleh disimpan sebagai lembaran kerja tertentu dalam buku kerja menggunakan parameter sheet_name
. Nilai lalai parameter ini ialah Sheet1:
<code class="language-python">df.to_excel('my_file.xlsx')</code>
tersedia untuk lebih banyak pilihan apabila menyimpan ke spreadsheet. Jika anda ingin menyimpan pelbagai bingkai data ke fail yang sama, anda boleh menggunakan sintaks berikut: ExcelWriter
<code class="language-python">df.to_excel('my_file.xlsx', sheet_name = 'My Sheet')</code>Untuk menambah bingkai data ke spreadsheet yang sedia ada, gunakan parameter
. Sila ambil perhatian bahawa mod tambahan hanya disokong apabila enjin ditentukan sebagai OpenPyxl: mode
<code class="language-python">import pandas as pd workbook = pd.read_excel('my_file.xlsx') # 创建workbook的副本 workbook_2 = workbook.copy() with pd.ExcelWriter('my_file_1.xlsx') as writer: workbook.to_excel(writer, sheet_name='Sheet1') workbook_2.to_excel(writer, sheet_name='Sheet2')</code>Di samping itu, gunakan
dan date_format
untuk menetapkan nilai tarikh dan masa: datetime_format
<code class="language-bash">pip3 install pandas</code>
Baca versi lama (.xls) Spreadsheet:
spreadsheet lama dengan lanjutan .xls boleh dibaca menggunakan sintaks yang sama dalam panda:
<code class="language-python">import pandas as pd workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx') workbook.head()</code>
Walaupun fungsi read_excel()
yang sama digunakan, Pandas menggunakan enjin XLRD untuk membacanya. Anda boleh membaca dan menulis kepada spreadsheet lama menggunakan sintaks yang sama yang dibincangkan dalam tutorial ini sebelum ini.
Penerangan ringkas fail CSV:
CSV bermaksud "nilai yang dipisahkan koma" (kadang-kadang dipanggil nilai yang dipisahkan karakter jika pembatas yang digunakan bukan koma), dan namanya jelas. Fail CSV biasa kelihatan seperti ini:
<code class="language-python">import sys workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx', encoding=sys.getfilesystemencoding())</code>
Spreadsheet boleh ditukar kepada fail CSV untuk memudahkan parsing. Sebagai tambahan kepada panda, anda juga boleh menghuraikan fail CSV dengan mudah menggunakan modul CSV di Python:
<code class="language-python">workbook = pd.read_excel('~/Desktop/import-export-data.xlsx', usecols = 'A:E') workbook.head()</code>
Kesimpulan:
Membuat dan menghuraikan spreadsheet tidak dapat dielakkan apabila bekerja dengan aplikasi web yang besar. Oleh itu, yang biasa dengan perpustakaan parsing hanya boleh membantu jika diperlukan.
FAQ:
pandas.read_excel()
untuk membaca fail Excel. pandas.read_csv()
. pip install pandas
dan pip install openpyxl
. Respons yang disemak ini mengekalkan makna asal semasa menyusun semula ayat-ayat dan menggunakan sinonim untuk mencapai pseudo-asal.
Atas ialah kandungan terperinci Menggunakan Python untuk menghuraikan data spreadsheet. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!