Alibrown's picture
Create app.py
55cfc4b verified
raw
history blame
4.74 kB
import streamlit as st
from PIL import Image
import io
import traceback
import time
def compress_image(image, format='webp', quality=85):
try:
# Korrektur: Wandle 'jpg' in 'jpeg' um
save_format = 'jpeg' if format.lower() == 'jpg' else format
# Korrektur: Quality-Wert wird umgekehrt angewendet
adjusted_quality = 101 - quality # Dies dreht die Skala um
img_byte_arr = io.BytesIO()
image.save(img_byte_arr, format=save_format.upper(), quality=adjusted_quality)
img_byte_arr.seek(0)
return Image.open(img_byte_arr)
except Exception as e:
st.error(f"Image compression error: {e}")
st.error(traceback.format_exc())
return None
def main():
st.title("Image optimization tool")
st.sidebar.header("Optimization settings")
uploaded_file = st.file_uploader("Select an image", type=['jpg', 'png', 'jpeg', 'webp'])
if uploaded_file is not None:
try:
original_image = Image.open(uploaded_file)
current_format = original_image.format.lower() if original_image.format else uploaded_file.name.split('.')[-1].lower()
current_format = 'jpeg' if current_format == 'jpg' else current_format
st.subheader("Original image")
st.image(original_image, caption=f"Original image ({current_format.upper()})")
original_size_bytes = len(uploaded_file.getvalue())
st.write(f"Original image size: {original_size_bytes} Bytes")
compression_quality = st.sidebar.slider(
"Compression quality (100 = best quality, 1 = smallest file)",
min_value=1,
max_value=100,
value=85
)
target_formats = [fmt for fmt in ['webp', 'jpg', 'png'] if fmt != current_format]
target_format = st.sidebar.selectbox(
"Target format",
target_formats
)
st.warning("⚠️ Please click 'Optimize Image' ONLY ONCE'!")
progress_bar = st.progress(0)
if st.button("Optimize image"):
try:
progress_bar.progress(20)
time.sleep(0.5)
optimized_image = compress_image(
original_image,
format=target_format,
quality=compression_quality
)
progress_bar.progress(60)
time.sleep(0.5)
if optimized_image:
save_format = 'jpeg' if target_format.lower() == 'jpg' else target_format
img_byte_arr = io.BytesIO()
optimized_image.save(img_byte_arr, format=save_format.upper(), quality=101-compression_quality)
img_byte_arr.seek(0)
progress_bar.progress(100)
time.sleep(0.5)
optimized_size_bytes = img_byte_arr.getbuffer().nbytes
compression_ratio = (1 - optimized_size_bytes / original_size_bytes) * 100
st.subheader("Optimization results")
col1, col2 = st.columns(2)
with col1:
st.image(optimized_image, caption=f"Optimized ({target_format.upper()})")
with col2:
st.write(f"Original size: {original_size_bytes} Bytes")
st.write(f"Optimized size: {optimized_size_bytes} Bytes")
st.write(f"Compression rate: {compression_ratio:.2f}%")
st.download_button(
label=f"Download {target_format.upper()}",
data=img_byte_arr,
file_name=f"optimized_image.{target_format}",
mime=f"image/{target_format}"
)
progress_bar.empty()
except Exception as e:
st.error(f"Image optimization error: {e}")
progress_bar.empty()
except Exception as e:
st.error(f"Error loading image: {e}")
if __name__ == "__main__":
main()