濮阳杆衣贸易有限公司

主頁 > 知識庫 > 如何利用Python批量處理行、列和單元格詳解

如何利用Python批量處理行、列和單元格詳解

熱門標(biāo)簽:地圖標(biāo)注多個 B52系統(tǒng)電梯外呼顯示E7 萊蕪電信外呼系統(tǒng) 銀川電話機器人電話 企業(yè)微信地圖標(biāo)注 沈陽防封電銷電話卡 高德地圖標(biāo)注收入咋樣 怎么辦理400客服電話 鶴壁手機自動外呼系統(tǒng)違法嗎

精確調(diào)整工作表的行高和列寬

步驟

  1. 打開工作簿。
  2. 遍歷所有工作表

核心代碼

for i in workbook.sheets:
	value = i.range('A1').expand('table')
	value.column_width = 12
	value.row_height = 20
workbook.save()

批量更改多個工作簿的數(shù)據(jù)格式

步驟:

  1. 列出文件夾中所有子文件
  2. 遍歷打開子文件
  3. 遍歷工作表
  4. 獲取工作表的最后一行
  5. 將指定列從上到下修改

核心代碼

#遍歷工作表
for j in workbook.sheets:
	# 獲取最后一行
	row_num = j['A1'].current_region.last_cell.row
	# 數(shù)據(jù)格式修改
	j['A2:A{}'.format(row_num)].number_format = 'm/d'
	j['D2:D{}'.format(row_num)].number_format = '¥#,##0.00'
workbook.save()
workbook.close()

使用xwings模塊中的number format屬性來設(shè)置單元格區(qū)域中數(shù)據(jù)的格式。該屬性的取值為一個代表特定格式的字符串,與Excel的“設(shè)置單元格格式”

對話框中“數(shù)字”選項卡下設(shè)置的格式對應(yīng)。

批量更改工作簿的外觀格式

難點應(yīng)該是外觀格式如何更改了吧,這里介紹一些常用的外觀格式。

j 是工作表

設(shè)置字體格式

修改字體為宋體

j['A1:H1'].api.Font.Name = '宋體'

修改字號

j['A1:H1'].api.Font.Size= 10  # 10磅

字體加粗

j['A1:H1'].api.Font.Bold= True  

字體顏色

# 白色
j['A1:H1'].api.Font.Color= xw.utils.rgb_to_int((255,255,255)) 

單元格填充顏色

# 填充顏色為黑色
j['A1:H1'].Color= xw.utils.rgb_to_int((0,0,0)) 

對齊方式

# 水平對齊方式為 居中
j['A1:H1'].api.HorizontalAlignment = xw.constants.HAlign.xlHAlignCenter

# 垂直對齊方式為 居中
j['A1:H1'].api.VerticalAlignment= xw.constants.VAlign.xlVAlignCenter

以上是一列的如果是正文,j['A1:H1']變成 j['A2'].expand('table') 就可以了

添加合適粗細(xì)的邊框

# 遍歷所有的單元格
for cell in j['A1'].expand('table'):
	for b in range(7,12):
		# 設(shè)置單元格的邊框線型
		cell.api.Borders(b).LineStyle = 1
		# 設(shè)置單元格的邊框粗細(xì)
		cell.api.Borders(b).Weight = 2

替換工作簿的行數(shù)據(jù)

核心代碼

# 遍歷工作表
for j in eorkbook.sheets:
	# 獲取工作表數(shù)據(jù)
	value = j['A2'].expand('table').value
	#按行遍歷工作表數(shù)據(jù)
	for index,val in enumerate(value):
		# 判斷行數(shù)據(jù)是否是這個
		if val == ['背包',16,65]:
			# 是的話替換為新數(shù)據(jù)
			value[index] = ['雙肩包',36,79]
	#將完成替換的數(shù)據(jù)寫入工作表中
	j['A2'].expand('table').value = value
workbook.save()

enumerate()是Python的內(nèi)置函數(shù),用于將一個可遍歷的數(shù)據(jù)對象(如列表、元組或字符串等)組合為一個索引序列,可同時得到數(shù)據(jù)對象的索引及對應(yīng)的值,一般用在for語句當(dāng)中。該函數(shù)的語法格式和常用參數(shù)含義如下。

enumerate(sequenxe,[start=0])
# start 是索引的起始位置

如果是修改指定行什么辦呢?因為列是在行的第幾個單元格中我們可以按如下代碼進行修改

#按行遍歷工作表數(shù)據(jù)
for index,val in enumerate(value):
	# 修改第三個單元格,即第index行,第 3列,下標(biāo)是從0開始的
	val[2] = val[2] + 1
	# 替換整行數(shù)據(jù)
	value[index] = val

提取指定數(shù)據(jù)

import xlwings as xw
import pandas as pd
app = xw.App(visible = False, add_book = False) 
workbook = app.books.open('采購表.xlsx')  
worksheet = workbook.sheets
data = []
for i in worksheet:
    values = i.range('A1').expand().options(pd.DataFrame).value
    # 一次性提取工作表中所有符合條件的行數(shù)據(jù)
    filtered = values[values['采購物品'] == '復(fù)印紙'] 
    if not filtered.empty: 
        data.append(filtered)
new_workbook = xw.books.add() 
new_worksheet = new_workbook.sheets.add('復(fù)印紙') 
new_worksheet.range('A1').value = pd.concat(data, ignore_index = False) 
new_workbook.save('復(fù)印紙.xlsx')
workbook.close()
app.quit()

提取列數(shù)據(jù)

import xlwings as xw
import pandas as pd
app = xw.App(visible = False, add_book = False) 
workbook = app.books.open('采購表.xlsx')
worksheet = workbook.sheets 
column = ['采購日期', '采購金額']
data = []
for i in worksheet:
    values = i.range('A1').expand().options(pd.DataFrame, index = False).value
    filtered = values[column]  
    data.append(filtered)
new_workbook = xw.books.add()  
new_worksheet = new_workbook.sheets.add('提取數(shù)據(jù)') 
new_worksheet.range('A1').value = pd.concat(data, ignore_index = False).set_index(column[0])
new_workbook.save('提取表.xlsx') 
workbook.close()
app.quit()

追加行數(shù)據(jù)

import os
import xlwings as xw
newContent = [['雙肩包', '64', '110'], ['腰包', '23', '58']]
app = xw.apps.add()
file_path = '分部信息'  
file_list = os.listdir(file_path)  
for i in file_list:  
    if os.path.splitext(i)[1] == '.xlsx':  
        workbook = app.books.open(file_path + '\\' + i)  
        worksheet = workbook.sheets['產(chǎn)品分類表']
        values = worksheet.range('A1').expand()
        number = values.shape[0]  
        worksheet.range(number + 1, 1).value = newContent  
        workbook.save()
        workbook.close()
app.quit()

提取所有工作表的唯一值

import xlwings as xw
app = xw.App(visible = True, add_book = False)
workbook = app.books.open('上半年銷售統(tǒng)計表.xlsx')
data = []
for i, worksheet in enumerate(workbook.sheets):
    values = worksheet['A2'].expand('down').value
    data = data + values
data = list(set(data))
data.insert(0, '書名')
new_workbook = xw.books.add()
new_worksheet = new_workbook.sheets.add('書名')
new_worksheet['A1'].options(transpose = True).value = data
new_worksheet.autofit()
new_workbook.save('書名.xlsx')
workbook.close()
app.quit()

總結(jié)

到此這篇關(guān)于如何利用Python批量處理行、列和單元格的文章就介紹到這了,更多相關(guān)Python批量處理行、列和單元格內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python基礎(chǔ)之元編程知識總結(jié)
  • Python中用Decorator來簡化元編程的教程
  • Python中使用裝飾器和元編程實現(xiàn)結(jié)構(gòu)體類實例
  • 簡析Python函數(shù)式編程字符串和元組及函數(shù)分類與高階函數(shù)
  • python使用xpath獲取頁面元素的使用
  • Python元類與迭代器生成器案例詳解
  • Python BeautifulSoup基本用法詳解(通過標(biāo)簽及class定位元素)
  • python中使用 unittest.TestCase單元測試的用例詳解
  • Python接口自動化淺析unittest單元測試原理
  • python自動化八大定位元素講解
  • python一繪制元二次方程曲線的實例分析
  • 詳解Python自動化中這八大元素定位
  • python元組打包和解包過程詳解
  • 淺談Python的元編程

標(biāo)簽:烏魯木齊 呼倫貝爾 銀川 三亞 葫蘆島 呼倫貝爾 安慶 湘西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《如何利用Python批量處理行、列和單元格詳解》,本文關(guān)鍵詞  如何,利用,Python,批量,處理,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何利用Python批量處理行、列和單元格詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于如何利用Python批量處理行、列和單元格詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    福泉市| 永城市| 苍溪县| 彩票| 天台县| 灵丘县| 思茅市| 邵东县| 大港区| 巴楚县| 涡阳县| 阿坝| 驻马店市| 搜索| 常山县| 且末县| 宁海县| 博罗县| 五大连池市| 祁连县| 科技| 泉州市| 花垣县| 博爱县| 东台市| 双江| 马公市| 祥云县| 南部县| 郴州市| 武城县| 五大连池市| 闻喜县| 茶陵县| 保亭| 渝北区| 深水埗区| 定西市| 太仆寺旗| 建德市| 临沭县|