Jadual Kandungan
Buka lembaran kerja tertentu
Dapatkan data sel
Buat fail baru
Tambah Lembaran Kerja
lebih banyak pilihan apabila menyimpan spreadsheet
Rumah pembangunan bahagian belakang Tutorial Python Menggunakan Python untuk menghuraikan data spreadsheet

Menggunakan Python untuk menghuraikan data spreadsheet

Feb 20, 2025 am 09:46 AM

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:

  • Python menggabungkan perpustakaan seperti panda dan openpyxl untuk mudah menghuraikan data spreadsheet, termasuk membaca dan menulis fail XLSX, fail CSV, dan spreadsheet warisan. Ini menjadikannya mudah untuk memanipulasi dan menganalisis data yang disimpan dalam format ini.
  • Proses membaca spreadsheet termasuk mengimport modul Pandas, membuka fail spreadsheet, memilih lembaran kerja tertentu, dan mengekstrak nilai sel data tertentu. Pandas membaca spreadsheet sebagai jadual dan menyimpannya sebagai bingkai data, yang kemudiannya boleh menanyakan bingkai data untuk mengekstrak data tertentu.
  • Proses membuat spreadsheet adalah serupa dengan membuat bingkai data dan menyimpannya ke buku kerja, kemudian membuat lembaran kerja di dalam buku kerja dan menambah data ke sel -sel dalam buku kerja. Kelas Excelwriter di Pandas menyediakan lebih banyak pilihan untuk menyimpan data ke spreadsheet, termasuk membekalkan bingkai data ke spreadsheet sedia ada dan penetapan tarikh dan nilai masa.

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.

Using Python to Parse Spreadsheet Data

Sebagai contoh, dalam imej di atas, spreadsheet mengandungi hanya satu lembaran kerja "Sheet1". Sel "2a" sepadan dengan baris kedua dan lajur pertama. Nilai sel 2a ialah 1. Walaupun program dengan GUI memberikan huruf kepada nama lajur, apabila kita menghuraikan data, kita mulakan dengan nombor baris dan nombor lajur dari 0. Ini bermakna bahawa sel 2a akan sesuai dengan (1, 0), 4b akan sesuai dengan (1, 3), 3c akan sesuai dengan (2, 2), dan sebagainya.

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:

pip3 install pandas
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:

    Import modul pandas
  1. Buka fail spreadsheet (atau buku kerja)
  2. Pilih Lembaran Kerja
  3. Ekstrak nilai sel data tertentu
Buka fail spreadsheet

Pertama, mari kita buka fail di Python. Contoh spreadsheet berikut (disediakan oleh Container Learning):

pip3 install pandas

Pandas membaca spreadsheet sebagai meja dan menyimpannya sebagai DataFrame Pandas.

Jika fail mengandungi aksara bukan ascii, ia harus dibuka dalam format unicode:

import pandas as pd
workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx')
workbook.head()

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:

import sys
workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx', encoding=sys.getfilesystemencoding())

Di samping itu, anda boleh menggunakan parameter nrows dan skiprows untuk hanya membaca sejumlah baris, atau mengabaikan sejumlah baris tertentu pada mulanya.

Buka lembaran kerja tertentu

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):

workbook = pd.read_excel('~/Desktop/import-export-data.xlsx', usecols = 'A:E')
workbook.head()

Pelbagai lembaran kerja juga boleh dipilih sebagai penyimpanan kamus untuk bingkai data panda dengan lulus senarai ke sheet_name parameter:

# 读取名为'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)

Dapatkan data sel

Setelah memilih lembaran kerja ke bingkai data, anda boleh mengekstrak nilai sel data tertentu dengan menanyakan bingkai data Pandas:

# 读取前两个工作表和名为'Sheet 3'的工作表
worksheets = pd.read_excel('~/Desktop/import-export-data.xlsx', sheet_name = [0, 1, 'Sheet 3'])
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:

import pandas as pd
workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx')

# 打印'Product'列的第一个值
print(workbook['Product'].iloc[0])

=> Carretera

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.

  1. Import modul pandas
  2. simpan data ke buku kerja
  3. Buat lembaran kerja dalam buku kerja
  4. tambah gaya ke sel dalam buku kerja

Buat fail baru

Untuk membuat fail baru, anda terlebih dahulu memerlukan bingkai data. Mari kita buat semula jadual demo pada permulaan artikel:

print(workbook['Product'].loc[0])

=> Carretera

Anda kemudian boleh membuat fail spreadsheet baru dengan memanggil fungsi to_excel() ke bingkai data dan tentukan nama fail yang harus disimpan:

import pandas as pd

name = ['John', 'Mary', 'Sherlock']
age = [11, 12, 13]
df = pd.DataFrame({ 'Name': name, 'Age': age })
df.index.name = 'ID'

juga boleh menggunakan fungsi read_excel() untuk membuka fail yang sama.

Tambah Lembaran Kerja

Bingkai data boleh disimpan sebagai lembaran kerja tertentu dalam buku kerja menggunakan parameter sheet_name. Nilai lalai parameter ini ialah Sheet1:

df.to_excel('my_file.xlsx')

lebih banyak pilihan apabila menyimpan spreadsheet

Kelas

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

df.to_excel('my_file.xlsx', sheet_name = 'My Sheet')
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

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')
Di samping itu, gunakan

dan date_format untuk menetapkan nilai tarikh dan masa: datetime_format

pip3 install pandas

Baca versi lama (.xls) Spreadsheet:

spreadsheet lama dengan lanjutan .xls boleh dibaca menggunakan sintaks yang sama dalam panda:

import pandas as pd
workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx')
workbook.head()

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:

import sys
workbook = pd.read_excel('sample-xlsx-file-for-testing.xlsx', encoding=sys.getfilesystemencoding())

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:

workbook = pd.read_excel('~/Desktop/import-export-data.xlsx', usecols = 'A:E')
workbook.head()

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:

  • Bolehkah Python Parse Excel? Ya, Python boleh menghuraikan fail Excel menggunakan perpustakaan seperti panda dan openpyxl.
  • Apakah perpustakaan Python yang digunakan untuk menghuraikan fail Excel? Dua perpustakaan yang biasa digunakan adalah pandas dan openpyxl.
  • Bagaimana untuk mengekstrak data dari Excel menggunakan Python? anda boleh menggunakan fungsi pandas.read_excel() untuk membaca fail Excel.
  • Bolehkah saya menghuraikan fail CSV menggunakan python? Pandas juga boleh menghuraikan fail CSV. Fail CSV boleh dibaca menggunakan fungsi pandas.read_csv().
  • Bagaimana menggunakan panda untuk menapis dan memanipulasi data selepas parsing? Anda boleh menggunakan fungsi manipulasi data Pandas (seperti LOC, ILOC, dan Query) untuk menapis, memilih dan mengubah suai data mengikut pelbagai syarat.
  • Bagaimana untuk memasang panda perpustakaan yang diperlukan dan openpyxl? Anda boleh menggunakan PIP (Pengurus Pakej Python) untuk memasang Pandas dan OpenPyxl. Jalankan arahan 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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Mejiro Ryan Build Guide | Uma Musume Pretty Derby
1 bulan yang lalu By Jack chen
Rimworld Odyssey Cara Ikan
4 minggu yang lalu By Jack chen
Apakah had transaksi untuk pengguna asing di Alipay?
4 minggu yang lalu By 下次还敢

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial PHP
1504
276
Cara Mengendalikan Pengesahan API di Python Cara Mengendalikan Pengesahan API di Python Jul 13, 2025 am 02:22 AM

Kunci untuk menangani pengesahan API adalah untuk memahami dan menggunakan kaedah pengesahan dengan betul. 1. Apikey adalah kaedah pengesahan yang paling mudah, biasanya diletakkan dalam tajuk permintaan atau parameter URL; 2. BasicAuth menggunakan nama pengguna dan kata laluan untuk penghantaran pengekodan Base64, yang sesuai untuk sistem dalaman; 3. OAuth2 perlu mendapatkan token terlebih dahulu melalui client_id dan client_secret, dan kemudian bawa bearertoken dalam header permintaan; 4. Untuk menangani tamat tempoh token, kelas pengurusan token boleh dikemas dan secara automatik menyegarkan token; Singkatnya, memilih kaedah yang sesuai mengikut dokumen dan menyimpan maklumat utama adalah kunci.

Tutorial Python Fastapi Tutorial Python Fastapi Jul 12, 2025 am 02:42 AM

Untuk mewujudkan API moden dan cekap menggunakan Python, FastAPI disyorkan; Ia berdasarkan kepada jenis python standard yang diminta dan secara automatik dapat menghasilkan dokumen, dengan prestasi yang sangat baik. Selepas memasang FastAPI dan Asgi Server UVicorn, anda boleh menulis kod antara muka. Dengan menentukan laluan, menulis fungsi pemprosesan, dan data yang kembali, API boleh dibina dengan cepat. FastAPI menyokong pelbagai kaedah HTTP dan menyediakan sistem dokumentasi Swaggersui dan Redoc yang dihasilkan secara automatik. Parameter URL boleh ditangkap melalui definisi laluan, manakala parameter pertanyaan boleh dilaksanakan dengan menetapkan nilai lalai untuk parameter fungsi. Penggunaan rasional model Pydantic dapat membantu meningkatkan kecekapan dan ketepatan pembangunan.

Cara Menguji API dengan Python Cara Menguji API dengan Python Jul 12, 2025 am 02:47 AM

Untuk menguji API, anda perlu menggunakan Perpustakaan Permintaan Python. Langkah -langkahnya adalah untuk memasang perpustakaan, menghantar permintaan, mengesahkan respons, menetapkan masa dan cuba semula. Pertama, pasang perpustakaan melalui PipinstallRequests; kemudian gunakan permintaan.get () atau requests.post () dan kaedah lain untuk menghantar permintaan GET atau pos; Kemudian semak respons.status_code dan response.json () untuk memastikan hasil pulangan mematuhi jangkaan; Akhirnya, tambah parameter tamat masa untuk menetapkan masa tamat, dan menggabungkan perpustakaan semula untuk mencapai percubaan automatik untuk meningkatkan kestabilan.

Skop pembolehubah python dalam fungsi Skop pembolehubah python dalam fungsi Jul 12, 2025 am 02:49 AM

Dalam Python, pembolehubah yang ditakrifkan di dalam fungsi adalah pembolehubah tempatan dan hanya sah dalam fungsi; Ditakrifkan secara luaran adalah pembolehubah global yang boleh dibaca di mana sahaja. 1. Pembolehubah tempatan dimusnahkan kerana fungsi dilaksanakan; 2. Fungsi ini boleh mengakses pembolehubah global tetapi tidak dapat diubahsuai secara langsung, jadi kata kunci global diperlukan; 3. Jika anda ingin mengubah suai pembolehubah fungsi luar dalam fungsi bersarang, anda perlu menggunakan kata kunci nonlocal; 4. Pembolehubah dengan nama yang sama tidak mempengaruhi satu sama lain dalam skop yang berbeza; 5. Global mesti diisytiharkan apabila mengubah suai pembolehubah global, jika tidak, kesilapan unboundlocalerror akan dibangkitkan. Memahami peraturan ini membantu mengelakkan pepijat dan menulis lebih banyak fungsi yang boleh dipercayai.

Akses objek JSON bersarang di Python Akses objek JSON bersarang di Python Jul 11, 2025 am 02:36 AM

Cara untuk mengakses objek JSON bersarang di Python adalah untuk menjelaskan struktur dan kemudian lapisan indeks dengan lapisan. Pertama, sahkan hubungan hierarki JSON, seperti kamus kamus bersarang atau senarai; Kemudian gunakan kunci kamus dan indeks senarai untuk mengakses lapisan mengikut lapisan, seperti data "butiran" ["zip"] untuk mendapatkan pengekodan zip, data "butiran" [0] untuk mendapatkan hobi pertama; Untuk mengelakkan keyError dan indexError, nilai lalai boleh ditetapkan oleh kaedah .get (), atau fungsi enkapsulasi Safe_get boleh digunakan untuk mencapai akses yang selamat; Untuk struktur yang kompleks, cari rekursif atau gunakan perpustakaan pihak ketiga seperti JMespath untuk mengendalikan.

Cara Menghuraikan Jadual HTML dengan Python dan Pandas Cara Menghuraikan Jadual HTML dengan Python dan Pandas Jul 10, 2025 pm 01:39 PM

Ya, anda boleh menghuraikan jadual HTML menggunakan python dan panda. Pertama, gunakan fungsi pandas.read_html () untuk mengekstrak jadual, yang boleh menghuraikan elemen HTML dalam laman web atau rentetan ke dalam senarai dataframe; Kemudian, jika jadual tidak mempunyai tajuk lajur yang jelas, ia boleh ditetapkan dengan menentukan parameter header atau menetapkan secara manual atribut. Untuk halaman yang kompleks, anda boleh menggabungkan Perpustakaan Permintaan untuk mendapatkan kandungan HTML atau menggunakan BeautifulSoup untuk mencari jadual tertentu; Perhatikan perangkap biasa seperti rendering JavaScript, masalah pengekodan, dan pengiktirafan pelbagai meja.

Python def vs lambda menyelam dalam Python def vs lambda menyelam dalam Jul 10, 2025 pm 01:45 PM

DEF sesuai untuk fungsi kompleks, menyokong pelbagai baris, rentetan dokumen dan bersarang; Lambda sesuai untuk fungsi tanpa nama mudah dan sering digunakan dalam senario di mana fungsi diluluskan oleh parameter. Keadaan memilih DEF: ① Badan fungsi mempunyai pelbagai baris; ② Penerangan dokumen diperlukan; ③ dipanggil pelbagai tempat. Apabila memilih Lambda: ① Penggunaan Satu Masa; ② Tiada nama atau dokumen yang diperlukan; ③ Logik mudah. Perhatikan bahawa Lambda kelewatan pembolehubah mengikat boleh membuang kesilapan dan tidak menyokong parameter lalai, penjana, atau asynchronous. Dalam aplikasi sebenar, fleksibel memilih mengikut keperluan dan memberi keutamaan kepada kejelasan.

Bagaimana cara menghuraikan fail JSON yang besar di Python? Bagaimana cara menghuraikan fail JSON yang besar di Python? Jul 13, 2025 am 01:46 AM

Bagaimana cara mengendalikan fail JSON yang besar di Python? 1. Gunakan Perpustakaan IJSON untuk mengalir dan mengelakkan limpahan memori melalui parsing item demi item; 2. Jika dalam format Jsonlines, anda boleh membacanya dengan garis dan memprosesnya dengan json.loads (); 3. Atau memecah fail besar ke dalam kepingan kecil dan kemudian memprosesnya secara berasingan. Kaedah ini dengan berkesan menyelesaikan masalah batasan memori dan sesuai untuk senario yang berbeza.

See all articles