顯示具有 漁產品交易行情 標籤的文章。 顯示所有文章
顯示具有 漁產品交易行情 標籤的文章。 顯示所有文章

2025年6月4日 星期三

利用JinJa2模版語言設計漁產品交易行情Word模版

 


1. template.doc


2.python程式
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import requests
import json
from docxtpl import DocxTemplate

# 取得JSON資料
r = requests.get('https://data.moa.gov.tw/Service/OpenData/FromM/AquaticTransData.aspx')
json_data = json.loads(r.text)

# 整理資料(轉換為適合模板的格式)
data = []
for item in json_data:
    data.append({
        '交易日期': item.get('交易日期'),
        '品種代碼': item.get('品種代碼'),
        '魚貨名稱': item.get('魚貨名稱'),
        '市場名稱': item.get('市場名稱'),
        '上價': str(item.get('上價')),
        '中價': str(item.get('中價')),
        '下價': str(item.get('下價')),
        '交易量': str(item.get('交易量')),
        '平均價': str(item.get('平均價'))
    })

# 套用模板
tpl = DocxTemplate("template.docx")
context = { 'data': data }
tpl.render(context)
tpl.save("AquaticTransData.docx")

print("資料已套用模板並儲存為 AquaticTransData.docx")

執行結果:
如最上面的圖片

2024年6月9日 星期日

用Python把最近漁產品交易行情資料並儲存成Word檔案

範例一、取得最近漁產品交易行情資料並儲存成Word檔案
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
import requests
import json
from docx import Document

# 從URL取得JSON資料
r = requests.get('https://data.moa.gov.tw/Service/OpenData/FromM/AquaticTransData.aspx')
json_data = json.loads(r.text)

# 建立一個新的Word文件
doc = Document()
doc.add_heading('漁產品交易行情', level=1)

# 寫入標題行
headers = ['交易日期', '品種代碼', '魚貨名稱', '市場名稱', '上價', '中價', '下價', '交易量', '平均價']
table = doc.add_table(rows=1, cols=len(headers))
hdr_cells = table.rows[0].cells
for idx, header in enumerate(headers):
    hdr_cells[idx].text = header

# 寫入資料
for item in json_data:
    row = [
        item.get('交易日期'),
        item.get('品種代碼'),
        item.get('魚貨名稱'),
        item.get('市場名稱'),
        str(item.get('上價')),
        str(item.get('中價')),
        str(item.get('下價')),
        str(item.get('交易量')),
        str(item.get('平均價'))
    ]
    row_cells = table.add_row().cells
    for idx, cell_value in enumerate(row):
        row_cells[idx].text = str(cell_value)

# 儲存到Word檔案
doc.save('AquaticTransData.docx')

print("資料已儲存到 AquaticTransData.docx")

執行結果:
資料已儲存到 AquaticTransData.docx

開啟AquaticTransData.docx的畫面如下:


範例二、加上格線

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import requests
import json
from docx import Document
from docx.oxml import OxmlElement
from docx.oxml.ns import qn

# 從URL取得JSON資料
r = requests.get('https://data.moa.gov.tw/Service/OpenData/FromM/AquaticTransData.aspx')
json_data = json.loads(r.text)

# 建立一個新的Word文件
doc = Document()
doc.add_heading('漁產品交易行情', level=1)

# 寫入標題行
headers = ['交易日期', '品種代碼', '魚貨名稱', '市場名稱', '上價', '中價', '下價', '交易量', '平均價']
table = doc.add_table(rows=1, cols=len(headers))
hdr_cells = table.rows[0].cells
for idx, header in enumerate(headers):
    hdr_cells[idx].text = header

# 寫入資料
for item in json_data:
    row = [
        item.get('交易日期'),
        item.get('品種代碼'),
        item.get('魚貨名稱'),
        item.get('市場名稱'),
        str(item.get('上價')),
        str(item.get('中價')),
        str(item.get('下價')),
        str(item.get('交易量')),
        str(item.get('平均價'))
    ]
    row_cells = table.add_row().cells
    for idx, cell_value in enumerate(row):
        row_cells[idx].text = str(cell_value)

# 設置表格邊框
def set_table_border(table):
    tbl = table._element
    tbl_pr = tbl.tblPr
    tbl_borders = OxmlElement('w:tblBorders')
    for border_name in ['top', 'left', 'bottom', 'right', 'insideH', 'insideV']:
        border = OxmlElement(f'w:{border_name}')
        border.set(qn('w:val'), 'single')
        border.set(qn('w:sz'), '4')
        border.set(qn('w:space'), '0')
        border.set(qn('w:color'), 'auto')
        tbl_borders.append(border)
    tbl_pr.append(tbl_borders)

# 加上格線
set_table_border(table)

# 儲存到Word檔案
doc.save('AquaticTransData.docx')

print("資料已儲存到 AquaticTransData.docx")

執行結果:
資料已儲存到 AquaticTransData.docx

開啟AquaticTransData.docx的畫面如下:

範例三、轉成PDF

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import requests
import json
from docx import Document
from docx.oxml import OxmlElement
from docx.oxml.ns import qn
from docx2pdf import convert

# 從URL取得JSON資料
r = requests.get('https://data.moa.gov.tw/Service/OpenData/FromM/AquaticTransData.aspx')
json_data = json.loads(r.text)

# 建立一個新的Word文件
doc = Document()
doc.add_heading('漁產品交易行情', level=1)

# 寫入標題行
headers = ['交易日期', '品種代碼', '魚貨名稱', '市場名稱', '上價', '中價', '下價', '交易量', '平均價']
table = doc.add_table(rows=1, cols=len(headers))
hdr_cells = table.rows[0].cells
for idx, header in enumerate(headers):
    hdr_cells[idx].text = header

# 寫入資料
for item in json_data:
    row = [
        item.get('交易日期'),
        item.get('品種代碼'),
        item.get('魚貨名稱'),
        item.get('市場名稱'),
        str(item.get('上價')),
        str(item.get('中價')),
        str(item.get('下價')),
        str(item.get('交易量')),
        str(item.get('平均價'))
    ]
    row_cells = table.add_row().cells
    for idx, cell_value in enumerate(row):
        row_cells[idx].text = str(cell_value)

# 設置表格邊框
def set_table_border(table):
    tbl = table._element
    tbl_pr = tbl.tblPr
    tbl_borders = OxmlElement('w:tblBorders')
    for border_name in ['top', 'left', 'bottom', 'right', 'insideH', 'insideV']:
        border = OxmlElement(f'w:{border_name}')
        border.set(qn('w:val'), 'single')
        border.set(qn('w:sz'), '4')
        border.set(qn('w:space'), '0')
        border.set(qn('w:color'), 'auto')
        tbl_borders.append(border)
    tbl_pr.append(tbl_borders)

# 加上格線
set_table_border(table)

# 儲存到Word檔案
word_filename = 'AquaticTransData.docx'
pdf_filename = 'AquaticTransData.pdf'
doc.save(word_filename)

# 轉換為PDF
convert(word_filename, pdf_filename)

print(f"資料已儲存到 {pdf_filename}")

執行結果:

  0%|          | 0/1 [00:00<?, ?it/s]
100%|██████████| 1/1 [00:45<00:00, 45.97s/it]
100%|██████████| 1/1 [00:46<00:00, 46.15s/it]
資料已儲存到 AquaticTransData.pdf

開啟AquaticTransData.pdf的畫面如下:



2024年6月8日 星期六

用Python自動生成最近吳郭魚在斗南市場的交易圖的簡報檔

 程式:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
from pptx import Presentation
from pptx.chart.data import CategoryChartData
from pptx.enum.chart import XL_CHART_TYPE
from pptx.util import Inches

import requests
import json
r = requests.get('https://data.moa.gov.tw/Service/OpenData/FromM/AquaticTransData.aspx')
text = json.loads(r.text)
tranDate = []
totalPrince = []
for row in text:
    if '吳郭魚' in row['魚貨名稱'] and '斗南' in row['市場名稱']:
        tranDate.append(row['交易日期'])
        totalPrince.append(row['平均價']*row['交易量'])



prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[5])
title = slide.shapes.title
title.text = "吳郭魚在斗南市場的交易圖"

chart_data = CategoryChartData()
chart_data.categories = tranDate
chart_data.add_series('吳郭魚', tuple(totalPrince))
x, y, cx, cy = Inches(2), Inches(2), Inches(6), Inches(4.5)
slide.shapes.add_chart(
    XL_CHART_TYPE.COLUMN_CLUSTERED, x, y, cx, cy, chart_data
)

prs.save("吳郭魚在斗南市場的交易圖.pptx")

執行結果: