piątek, 25 grudnia 2009

Wesołych Świąt

Z okazji świąt przygotowałem ciekawy skrypcik:
                 *                  
                ooo                 
               %oo%*                
              %%*oo*%               
             **ooo%oo*              
            **%%%*o%%o%             
                 %                  
                *%o                 
               %*%%%                
              **oo*o%               
             %%*o*o*%*              
            **%%*o**o%%             
           **o*o%o*%**%*            
          %%*o%%*%***%***           
         %%oo**%**oo%ooo*%          
        *%*%*%*%*oo%*%**%**         
       %ooooo*%%*o*oo*%*%*%%        
      *%oo**o*oo%oo%**ooo%%%%       
                 *                  
                ***                 
               o%o*o                
              %*%oo%*               
             o%*o*%**%              
            %***%oo%o*%             
           *o%o%%%%%%*%*            
          **%*o%%**o*%***           
         %*ooo%o%%o*%%**%%          
        *%%o%o***o%*%%%**o*         
       *****oo*oo*%%%**%%%o%        
      %***o%%**%%%o*oooo%***%       
     %o**o*o%***%%%o%o**%oooo*      
    o%o*o**oo*o%o**o%%%%%o%%**o     
   o*o%o%*%oo%*oo%%o*ooooo%**oo*    
  o*oo*o%%o*ooo%****oo*o%%o%o%*%%   
 *oo*ooo%o**o%**oo*o%%%o%o%oo%o*oo  
o**%ooo%o*o*o*%%o%*%%o%o%%o*oo%**** 

           Wesołych Świąt    


#!/usr/local/bin/python
# -*- coding: utf-8 -*-
import random

def ChristmasTree(levels, n, decoration=["*"]):
    """
    level - liczba poziomów drzewka
    n - wysokość pierwszego poziomu
    decoration - lista ozdób drzewka 
    """
    for j in range(1,levels+1):
        for i in range(j*n):
            line = ""
            for k in range(2*i+1):
                line +=  random.choice(decoration)
            print line.center(2*levels*n)
    print ""
    print u'Wesołych Świąt'.center(2*levels*n) 

ChristmasTree(3, 6, ["*","%","o"])

PS. potrafisz uzyskać podobny efekt w innym języku programowania?
Podejmij wyzwanie :)

środa, 7 października 2009

Wi-Fi router ze starego laptopa

Jestem w posiadaniu starego laptopa Fujitsu Siemens Amilo M7400, który nie ma (już) dysku twardego. Postanowiłem go wykorzystać do stworzenia wi-fi routerka (nie musze kupować access pointa i wykorzystam pozornie bezużytecznego lapka).

System nie może startować z dysku twardego, jedyne możliwości to PXE boot(odpada), live CD(nie będe miał prawa zapisu na nośnik), live USB(!).

Niestety na tym sprzęcie (256Mb RAMu) nie odpale Ubuntu 9.10, nawet Xubuntu też nie wydala.
Znalazłem jednak Lubuntu (dystrybucja ubuntu z lxde,
http://download.lxde.org/lubuntu-9.10/) - wypaliłem na USB(UNetbootin, pisałem o tym w którymś z poprzednich postów) i śmiga:)

Teraz tylko skonfigurować interface'y sieciowe, włączyć routing w kernelu(echo 1 > /proc/sys/net/ipv4/ip_forward) i napisać firewall'a.

Jeszcze ważna uwaga: żeby zadziałała karta sieciowa ipw2200 należy odpalić moduł fsam7400

$sudo modprobe fsam7400 radio=1

Gdyby ktoś potrzebował szyfrowania WPA, to musi sobie skompilać firmware ze źródeł(http://ipw2200.sourceforge.net/ + instrukcja: http://ubuntuforums.org/showthread.php?t=26623), mi WEP całkowice wystarcza(iwconfig $LAN essid [nazwa_sieci] key [s:tekstowy_klucz] channel [nr_kanału] power on).

piątek, 10 lipca 2009

Potrzebujesz małe forum ?

...dodatkowo z darmowym hostingiem...bez reklam...w domenie appspot.com

Właśnie napisałem malutkie forum w GAE bazujące na stylu phpBB.

jak to wygląda? tutaj jest przykład: small-forum

Stąd można pobrać najnowszą wersje: small forum na google code

Jak zainstalować?

znaleść w pliku main.py linijkę:


class AclUser:
__admin__ = 'Twój google login' #(login administratora)

w pliku app.yaml:
application: small-forum #zmienić na własną nazwę aplikacji
i wgrać forum:
$python appcfg.py update forum

piątek, 5 czerwca 2009

log1 CMS (video) HD

czwartek, 14 maja 2009

log1 CMS Beta Release

Kolejny CMS, tylko po co?

Pomysł napisania własnego systemu zarządzania treścią zrodził się już dawno. Głównym motywem była moja strona domowa składał się z kilku chaotycznych skryptów. System został napisany właściwie od zera. A jego najważniejsza cecha to prostota i wygoda użytkowania.
Najważniejsze jest w tym wszystkim to, ze nie wymaga bazy danych, tak więc aby przenieść stronę na inny serwer wystarczy, że przeniosę sobie katalog db/

Mówi się, że najlepsze programy to takie, które nie wymagają instrukcji. Według mnie to zależy do kogo dedykowany jest produkt, chociaż przyznam się, że rzadko sięgam do jakiekolwiek instrukcji :) Wydaje mi się, że to co napisałem nie wymaga instrukcji...

Najważniejsze cechy tego CMS's:

- łatwa instalacja, a właściwie jej brak:) wystarczy skopiować pliki z archiwum do katalogu serwera WWW z modułem do wykonywania skryptów PHP5. I zmienić prawa dostępu do 1 katalogi i 2 plików. Nie wymaga bazy danych:)

- łatwa obsługa. wszystko bazuje na 3 krokach.
1. pierwszy to podstawowe ustawienia takie jak: tytuł, opisy, słowa kluczowe itp.

2. drugi to tworzenie menu i tu fajne narzędzie: przesuwanie elementów menu



3. trzeci to uzupełnianie zawartości.

log1 CMS pozwala ( na razie) tylko na tworzenie jednopoziomowego menu.

Posiada również kanał RSS2, oraz własny silnik wyszukiwarki, interface dostępny w wersji polskiej i angielskiej.

Jednym słowem jest to ukierunkowany na prostotę system zarządzania treścią, do budowania stron opartych o jednopoziomowe menu.

Kilka słów o silniku:)

Program ten, jak wspomniałem nie wymaga bazy danych, wszystkie ustawienia zapisuje do plików XML a potem cache'uje w plikach tektowych.

bardziej obrazowo:
XML ---(0dczyt danych)---> modyfikacja --->( zapis)---> XML ----> .inc/.txt/.php

Jeszcze na koniec uwaga, log1 CMS nie posiada zbyt wielu opcji, został stworzony z myślą o małych stronach. Dlatego jeśli potrzebujesz czegoś o możliwościach Drupal'a czy Joomla'i nawet go nie pobieraj, bo się nie nada.

Oficialna strona:

log1 CMS oficjalna strona
pobierz

Jak na razie dostępne są 2 template'y
Oczywiście można łatwo tworzyć swoje.

Miłego użytkowania.

piątek, 24 kwietnia 2009

Google App Engine :: Klasa User

Google App Engine sprytnie rozwiązuje kwestie użytkowników, także przy tworzeniu aplikacji możemy łatwo wykorzystać klasę user z google api ( from google.appengine.api import users). Wystarczy, że użytkownik posiada konto w google, a my w łatwy sposób możemy 'wyciągnąć': nickname, user_id oraz jego adres mailowy.
Służą do tego metody - odpowiednio:
  1. nickname()
  2. user_id()
  3. email()
Co więcej dla naszego użytkownika przewidziany jest odpowiedni typ w bazie danych
- db.UserProperty()

A teraz zakładamy scenariusz: jak użytkownik nie jest zalogowany to przekierowywujemy go na stronę logowania, a jak jest zalogowany to wyświetlamy jego nickname oraz dajemy możliwość wylogowania się.


user = users.get_current_user()
if user:
self.response.out.write(user.nickname() + """ |
<a href="users.create_logout_url(self.request.uri)" >
Sign out</a>""")
else:
self.redirect(users.create_login_url(self.request.uri))


jeszcze możemy sprawdzić czy użytkownik ma uprawnienia administratora:
is_current_user_admin() - zwraca True jeśli tak.

Źródło (więcej na): http://code.google.com/appengine/docs/python/gettingstarted/

czwartek, 23 kwietnia 2009

Google App Engine - test możliwości

Google App Engine to świetne narzędzie do tworzenie dynamicznych stron oraz aplikacji webowych.
Ale to nie wszystko, bo to również darmowy hosting tych aplikacji + baza danych i wiele innych pożytecznych funkcji włącznie z panelem administracyjnym.

Co o bazie danych i języku Gql?

Niby obiektowe, ale z możliwością zadawania zapytań w języku gql - googlowa wersja sql'a :)
Co więcej zapytanie do bazy zwraca kolekcję obiektów.

Wpis w bazie jest obiektem stworzonej przez nas klasy, po kontakcie z ZODB czy Gadfly nie powinno to już nikogo dziwić.

Prosty przykład:

class BazaObiektow(db.Model):
author = db.UserProperty()
title
= db.StringProperty()
body
= db.TextProperty()

obiekty = db.GqlQuery("SELECT * FROM BazaObiektow")
# oczywiście można dodać jeszcze WHERE :)
# GqlQuery Class
for obiekt in obiekty:
#iterujemy po obiektach
self.response.out.write(str(obiekt.author) + '...wypisujemy co chcemy')


A jak się pisze kontroler i widok:

też fajnie, jest nawet system template'ów, co do google.appengine.api i cgi jest, jak narazie, troche słabo udokumentowane - trzeba się dużo naszukać, żeby znaleść informacje jak na przykład zapisać ciastka. Chociaż można się tego domyśleć :)

Dla zabawy napisałem prostą aplikacyjke do operacji na obrazach: zmiana wielkości( resize), obracanie o kąt( wielokrotność 90 stopni), odbicie symetryczne i poprawa kontrastu - a wszystko w oparciu o google.appengine.api - klasa images.

Można testować tutaj: My Images

aha, aplikacja jest po angielsku, ale łatwo się pokumać jakie funkcje do czego służą.

No i to by było na tyle...

Podsumowując - google app engine wywiera pozytywne wrażenia :)

sobota, 14 lutego 2009

Linux Live USB

Bardzo dużo dystrybucji Linuxa dostępnych jest w wersji Live CD, aby można było sobie przetestować możliwości dystrybucji bez instalacji na dysku. Dzięki narzędziu takiemu jak

UNetbootin

(Universal Netboot Installer), możemy zainstalować różne dystrybucje na nośnikach USB, na przykład Pendrive'ach. Oczywiście na podobnej zasadzie jak Live CD. Jak jest plus takiego rozwiązania?
System ładuje się nieco szybciej niż CD/DVD i nie musimy słuchać kręcącej się płytki ( dotyczy to głównie głośnych napędów).

Ponieważ startujący system 'rozpakowuje się' w RAMie zazwyczaj nie ma możliwości dokonania zmian na lokalnej kopii plików systemowych znajdujących sie na dysku USB( Oczywiście wyniki naszej pracy możemy zapisać na pendrivie.). Co jest jednocześnie wadą(1) i zaletą(2):

-ad 1: nie możemy zapisać zmian dokonych w systemie( na przykład zainstalowanych programów).
-ad 2: zazwyczaj nie możemy 'zepsuć systemu' :)

Ciekawe według mnie rozwiązanie zaproponował twórca dystrybucji Slax
Po pierwsze na stronie możemy powybierać moduły, które nas interesują i dołączyć do naszego systemu Live. Po drugie możemy zadecydować, które moduły mają być startowane w momencie bootowania systemu( katalog 'modules') lub które mają być uruchamiane na życzenie( katalog 'optional').

Zastosowania? na pewno jest wiele:
- Router
- Przenośny bezpieczny system na przykład do odtwarzania multimediów i dostępu do internetu.
- Ratunkowy
- itp.

Aby wystartować z dysku USB, nasz BIOS musi mieć taką opcje ( zazwyczaj nie ma z tym problemu w większości Laptopów), gorzej ze starszymi PC-tami. Należy w Boot sequence zaznaczyć jako pierwszy 'USB Drive' ( nazwa może być nie co inna, ale na pewno z 'USB' :) )

Gdy zaczynałem zabawe z Live USB w ręce wpadł mi MySlax Creator
bardzo fajna zabawka umożliwiająca w łatwy sposób wyklikać własnego Slaxa( a nawet wybrać tapetę na pulpit i ustalić hasło dla root'a :) )

Niestety programik nie działa z najnowszą wersją Slaxa 6.x, ( ja bawiłem się wtedy wersją Slaxa 5.1.8)

czwartek, 5 lutego 2009

Dlaczego Python? - czyli "programowanie z klocków" :)

Dlaczego w Pythonie pisze się tak łatwo szybko i przyjemnie?

Jedną z zalet Pythona jest super prosta składnia, która pozwala pisać bardzo zwięzły kod. Pamiętam taki argument: dlaczego znaki {, } w C są lepsze niż begin i end Pascala? - bo pozawalają każdorazowo zaoszczędzić 6 znaków :) Idąc tą drogą można napisać, że Python jest lepszy na przykład od Javy, bo oszczędza jeszcze te 2 znaki :)

Wymuszanie wcięć w kodzie skutkuje dobrymi nawykami - dotyczy to przede wszystkim początkujących programistów. Ale ma też swoje wady: trudniej jest przenieść fragment kodu na przykład do innej klasy, a zmiana głębokości wcięcia zazwyczaj zmienia działanie fragmentu kodu.
Python jest w pełni obiektowy, ale nic nie stoi na przeszkodzie, żeby pisać w nim strukturalnie - co kto lubi. A znam takie języki w których można pisać tylko i wyłącznie obiektowo ( żeby wypisać 'Hello World' na ekran trzeba napisać klasę, lol).

Spotkałem się z argumentem, że Python jest wolny. Jak na język skryptowy nie jest wcale taki wolny, choć porównywanie jego szybkości z C++ nie ma raczej sensu.

Przede wszystkim pisanie programów w Pythonie przypomina budowanie go z klocków - gotowych komponentów. Biblioteki tego języka w większości napisane są w czystym C dzięki czemu musi on być szybki.
Jak wiadomo, jest to język skryptowy tak jak Perl, PHP, Ruby czy wiele innych, wirtualna maszyna potrafi skonwertować sobie skrypcik do bytecode'u, a wszysto po to żeby działał czybciej.

Jednym z argumentów przemawiających za tym żeby uczyć/nauczyć się pythona jest fakt, że używa go Google( tylko mi nie mówcie: " ja używam Yahoo albo wyszukiwarki onetu" :) ) i NASA.

Każdy język programowania ma swoje zastosowanie, jednakże pole potencjalnego wykorzystania Pythona jest ogromne: począwszy od aplikacji webowych, a skończywszy na obliczeniach( w Pythonie nie ma zakresu liczb!!!, jedynym ograniczeniem jest fizyczna wielkość zasobów Twojego komputera). No może z wyjątkiem gier..., chociaż jest w końcu Pygame, VPython czy Ogre... :)

Ponadto łatwa konwersja typów, listy i kroki, a wszystko po to by ułatwić życie programiści.

Zresztą w sieci pojawia się wiele porównać typu C++ vs Java vs Python, w których nie wiedzieć czemu ;) Python zawsze wygrywa.

wtorek, 3 lutego 2009

Python i PicasaAPI: czyli znowu zdjęcia:)

Treści tutaj zawarte mają na celu pokazanie możliwości języka Python

Problem:


Jan Kowalski ( zbieżność nazwisk przypadkowa) ma konto Google, korzysta też z Picasy, ma kilka albumów, a w nich swoje zdjęcia.

Załóżmy, że chcemy je wszystkie sobie pobrać odtwarzając strukturę katalogów czyli na przykład:

jas.kowalski@gmail.com
|
| ---->wakacje2008 -> [zdjęcia]
|
|---->impreza urodzinowa -> [zdjęcia]
|
|---->wakacje2009 -> [zdjęcia]

itd.

Rozwiązanie:

Z pomocą jak zwykle przychodzi Python i w tym przypadku PicasaApi.

Oto przykład rozwiązania:

skrypt

skrypt.py

Będziemy też potrzebowali biblioteki gdata-python-client:

http://code.google.com/p/gdata-python-client/downloads/list

w sumie nie potrzebujemy wszystkich bibliotek, wystarczą 3:
gdata.photos.service.py
gdata.media.py
gdata.geo.py

a najprościej spkopiować cały katalog gdata do katalogu głównego skryptu.

enjoy

Ściąganie wszystkich zdjęć wybranego użytkownika z portalu Nasza-Klasa - wersja 3

UWAGA: Sktypt ma wyłącznie na celu pokazanie możliwości języka Python i jego bibliotek. Autor nie ponosi żadnej odpowiedzialności za działania skryptu oraz ewentualne straty nim spowodowane, pamiętaj korzystasz z niego na własną odpowiedzialność. Przed skorzystaniem upewnij się, że jego działanie jest zgodne z regulaminem serwisu Nasza-Klasa.

Udostępniam najnowszą i najbardziej dopracowaną wersję skryptu, w której nie trzeba podawać parametru max, ponieważ sprawdzam id ostatniego zdjęcia. To praktycznie wystarcza, bo jeśli użytkownik usunie jakieś zdjęcie pomiędzy to po prostu nie zostanie ono poprane( 404).

skrypt.py

potrzebna biblioteka httplib2:

httplib2


A więc ostateczna lista parametrów:
naszLogin naszeHasło Id

PS.
Proszę nie męczcie mnie już pytaniami jak zainstalować pythona czy jakieś biblioteki, albo dlaczego skrypt nie działa.

niedziela, 1 lutego 2009

Nasza-Klasa: pobieranie zdjęć - poprawiona wersja

UWAGA: Sktypt ma wyłącznie na celu pokazanie możliwości języka Python i jego bibliotek. Autor nie ponosi żadnej odpowiedzialności za działania skryptu oraz straty nim spowodowane, pamiętaj korzystasz z niego na własną odpowiedzialność. Przed skorzystaniem upewnij się, że jego działanie jest zgodne z regulaminem serwisu Nasza-Klasa.

Nawiązując do mojego wcześniejszego posta , po drobnym researchu wyciągnełem kilka wniosków, które zaowocowały drugą wersją sktyptu.

Po pierwsze nie musimy się już przejmować ciastkami( cookies) za to lista parametrów programu wydłużyła się o 2 i teraz wygląda tak:

nasza-klasa.py TwójLoginDoNK TwojeHasło IdOsobyKtórejZdjeciaChcemyPobrać MaxZdjeć

przy czym czwarty parametr jest opcjonalny i jeżeli nie wpiszemy nic - to przyjmie domyślną wartość - 50.

Po Drugie: jak zauważyłem RSS zwraca tylko 10 ostatnich zdjęć ( da sie pobrać RSSa dla wszystkich zdjęć?) , wiec ten pomysł na razie odpada.

zobacz kod: kod
pobierz: nasza-klasa.py

enjoy.

Ściąganie wszystkich zdjęć wybranego użytkownika z portalu Nasza-Klasa

UWAGA: Sktypt ma wyłącznie na celu pokazanie możliwości języka Python i jego bibliotek. Autor nie ponosi żadnej odpowiedzialności za działania skryptu oraz straty nim spowodowane, pamiętaj korzystasz z niego na własną odpowiedzialność. Przed skorzystaniem upewnij się, że jego działanie jest zgodne z regulaminem serwisu Nasza-Klasa.

Napisałem prosty skrypcik do sciągania n pierwszych zdjęć użytkownika o znanym Id na Naszej-Kasie. Już tłumaczę jak on działa i co porzebujemy:

1) musimy mieć konto w serwisie Nasza-Klasa
2) musimy znać id użytkownika, którego zdjęcia chcemy pobrać: można je łatwo znaleść na przykład w pasku adresu url( http://nasza-klasa.pl/profile/xxxxxxx, gdzie xxxxxxx to właśnie to Id)
3) ponieważ mój sktypt jest troche prymitywny:) i nie sprawdza ilośći zdjęć naszego użytkownika musimy podać ile zdjęć chcemy ściągnąć - ale tu można podać spokojnue większą liczbe, bo skrypt jest odporny na błędny
4) i wreszcie najważniejsze: musimy mieć zainstalowanego pythona i parę bibliotek( przypuszczam że wszyskie są w katalogu lib Pythona)
5) WAŻNE: musimy pobrać cookie zalogowanego użytkowika, bo jak na razie skrypt tego nie robi, i wpisać je do zmiennej:

cookies = 'remember_me=...; __utma=...; cookies += ' nk_session=...'

polecam Live HTTP Header do tego celu, można je znaleść też w przeglądarce( Firefox2: Narzędzia->Opcje->Wyświetl Ciasteczka->'wpisujemy w filtrze: nasza-klasa'->i odczytujemy poszczególne ciastka)

jak uruchamiać?:

Linux:
$ python nasza-klasa.py Id max (np. $ python nasza-klasa.py 1234567 50)
Windows:
start->cmd i wpisujemy: nasza-klasa.py Id max

no i źródła:

nasza-klasa.py

miłej zabawy, pozdro

TO DO:
* ułatwić podawanie cookies
* oprzeć silnik na RSS/XML