PCM 파일을 배열로 만들기



PCM 파일을 배열로 만들고 싶은 경우가 있죠. 아래 파이썬 소스를 이용하면 아주 쉽게 배열을 만들 수 있습니다.



#!/usr/bin/python

import sys


def pcm_to_array(fn):

file = open(fn, 'rb')

byteBuffer = bytearray(file.read())

file.close()


count = 0

for index in range(0, len(byteBuffer), 2):

low  = byteBuffer[index]

high = byteBuffer[index+1]

file_out.write("0x%02x, 0x%02x, "%(low, high))

count = count + 1

if count == 8:

file_out.write("\n")

count = 0


file_out = open("array.txt", 'w')

pcm_to_array("pcm_file.pcm")  

file_out.close()




0xf7, 0xff, 0xf7, 0xff, 0x04, 0x00, 0x06, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0xff, 0xff, 

0x00, 0x00, 0x01, 0x00, 0x05, 0x00, 0x03, 0x00, 0x01, 0x00, 0x04, 0x00, 0x04, 0x00, 0x01, 0x00,


반응형

[파이썬, Python] XlsxWriter 설치 및 엑셀 출력 예제 (윈도우즈 환경)


Python에서 출력 결과를 엑셀로 만드는 방법은 여러가지가 있습니다.

구글링을 해보니... XlsxWriter를 사용하는 것이 좋다는 의견들이 있어서... 

XlsxWriter를 설치해서 사용해 보기로 했습니다. ^^



첫번째, 파일 내려받기

GitHub에 XlsxWriter Zip 파일 내려받기



위의 싸이트에 가서, 아래 그림처럼 Zip 파일을 내려 받습니다. 





두번째, install 하기

내려 받은 Zip 파일을 압축을 푼 다음, 아래와 같이, setup.py를 이용하여 install을 합니다.


C:\XlsxWriter-master>python setup.py install




세번째, 엑셀(Excel) 파일 출력 예제 해보기

XlsxWriter 싸이트에서 제공하는 아래 기본 예제를 카피하여 excel_test.py로 저장한 후에 실행 시켜 보니, 

예제에 있는 그림처럼 엑셀 파일 만들짐을 확인 할 수 있네요... (아래에 예제 파일 첨부했습니다.)


오~~~ 너무너무 쉽네용 ^^ 진작에 해 볼걸 그랬네요... ^^


<예제 파일> 

excel_test.py




import xlsxwriter

# Create a workbook and add a worksheet.
workbook = xlsxwriter.Workbook('Expenses01.xlsx')
worksheet = workbook.add_worksheet()

# Some data we want to write to the worksheet.
expenses = (
    ['Rent', 1000],
    ['Gas',   100],
    ['Food',  300],
    ['Gym',    50],
)

# Start from the first cell. Rows and columns are zero indexed.
row = 0
col = 0

# Iterate over the data and write it out row by row.
for item, cost in (expenses):
    worksheet.write(row, col,     item)
    worksheet.write(row, col + 1, cost)
    row += 1

# Write a total using a formula.
worksheet.write(row, 0, 'Total')
worksheet.write(row, 1, '=SUM(B1:B4)')

workbook.close()

_images/tutorial01.png

(출처: https://xlsxwriter.readthedocs.org/tutorial01.html)


<예제 파일 2> 


line_chart.py



#######################################################################
#
# An example of creating Excel Line charts with Python and XlsxWriter.
#
# Copyright 2013-2016, John McNamara, jmcnamara@cpan.org
#
import xlsxwriter

workbook = xlsxwriter.Workbook('chart_line.xlsx')
worksheet = workbook.add_worksheet()
bold = workbook.add_format({'bold': 1})

# Add the worksheet data that the charts will refer to.
headings = ['Number', 'Batch 1', 'Batch 2']
data = [
    [2, 3, 4, 5, 6, 7],
    [10, 40, 50, 20, 10, 50],
    [30, 60, 70, 50, 40, 30],
]

worksheet.write_row('A1', headings, bold)
worksheet.write_column('A2', data[0])
worksheet.write_column('B2', data[1])
worksheet.write_column('C2', data[2])

# Create a new chart object. In this case an embedded chart.
chart1 = workbook.add_chart({'type': 'line'})

# Configure the first series.
chart1.add_series({
    'name':       '=Sheet1!$B$1',
    'categories': '=Sheet1!$A$2:$A$7',
    'values':     '=Sheet1!$B$2:$B$7',
})

# Configure second series. Note use of alternative syntax to define ranges.
chart1.add_series({
    'name':       ['Sheet1', 0, 2],
    'categories': ['Sheet1', 1, 0, 6, 0],
    'values':     ['Sheet1', 1, 2, 6, 2],
})

# Add a chart title and some axis labels.
chart1.set_title ({'name': 'Results of sample analysis'})
chart1.set_x_axis({'name': 'Test number'})
chart1.set_y_axis({'name': 'Sample length (mm)'})

# Set an Excel chart style. Colors with white outline and shadow.
chart1.set_style(10)

# Insert the chart into the worksheet (with an offset).
worksheet.insert_chart('D2', chart1, {'x_offset': 25, 'y_offset': 10})
workbook.close()



(출처: http://xlsxwriter.readthedocs.org/example_chart_line.html?highlight=line%20chart)



[Chart 관련 자세한 옵션] : Chart Class : http://xlsxwriter.readthedocs.org/chart.html?highlight=tick%20mark


반응형


우선, 아래 링크에 접속해 보세요.



MySQL-python-1.2.5.win32-py2.7.exe를 내려받아서 실행 시킵니다.


아래와 같은 setup 화면이 나옵니다. Next 를 누르고 진행을 하면 특별한 어려움 없이 설치가 됩니다.





반응형

+ Recent posts