BelajarPython – Assalamualaikum wr. wb.

Jumpa lagi temen.. Kali ini, saya akan mengajak kalian untuk membuat mini aplikasi lagi.. Aplikasi apa? Penasaran ?  Langsung saja di simak ya..

Pengenalan aplikasi yang akan kita buat.

Aplikasi yang kita buat kali ini adalah Browser. Udah tau kan ? Ya seperti chrome atau mozila gitu..  Tapi dengan fitur yang seadanya saja ya… Oya, seperti biasa, Aplikasi ini saya posting dengan berbagai versi.. Dengan penambahan fitur di tiap versinya.. Jika kalian ingin melihat semua versi nya, KLIK DISINI ya…

Kali ini, saya akan memberikan versi yang ke 2.. Dimana pada versi ini saya akan menampilkan kotak untuk pergi ke sebuah web…

Rincian Lengkap Aplikasi Browser PySide Versi 2.0

Aplikasi ini menggunakan library PySide.. Jadi, kalian perlu menginstall library tersebut untuk menjalankan aplikasi ini.. Klik disini jika belum install..

Nama : mn-Browser 2.0
Versi : 2.0 || selanjutnya.
Bahasa : Python 3.x  || Install.
Modul : PySide || Install.
Baris Code : +-105 baris.
Penambahan : +-60  baris.
Terdiri dari : 1 class dan 7 metode.
Fitur : menambahkan kotak url.
Kelemahan : tidak ada pesan web tidak di temukan jika web tidak ada.
syarat menjalankan : Python 3.x, PySide, dan editor teks / IDE.
Cara menjalankan : install python 3 dan PySide, copy paste code program pada editor/IDE, simpan dalam file python(ekstensi ‘.py’), lalu jalankan.

Kalian juga bisa membuat code program ini menjadi file aplikasi loh.. iya file aplikasi seperti “exe” itu.. sehingga, nantinya kita cukup klik dua kali saja untuk menjalankan aplikasi ini… tanpa perlu repot – repot membuka nya di IDLE atau IDE python.. nah seperti apa caranya? cukup mudah kok.. dan saya juga sudah membuatkan tutorialnya.. untuk kalian yang menggunakan windows, KALIAN BISA KLIK DISINI ya temen – temen.. atau jika pada link pertama terlalu rumit, KALIAN BISA MENCOBA CARA INI ya…. dan bagi pengguna linux ? tenang saja.. bisa juga kok membuat file executable nya.. untuk melihat tutorialnya, KALIAN BISA KLIK DISINI temen – temen…

Code program aplikasi Browser PySide versi 2.0

Nah lalu seperti apa code program versi ini ? Oke, Berikut saya berikan code program nya ya…

from PySide import QtCore, QtGui, QtWebKit

import sys



class Browser(QtGui.QMainWindow):

def __init__(self, parent=None, url=''):

QtGui.QMainWindow.__init__(self)

self.parent = parent

self.resize(800, 600)

self.centralwidget = QtGui.QWidget(self)



self.default_url = "https://google.co.id"

self.urlTab = url



self.layout()

self.buatToolbar()

self.windowBrowser()

self.browse()



def layout(self):

self.layoutUtama = QtGui.QHBoxLayout(self.centralwidget)

self.layoutUtama.setContentsMargins(0, 0, 0, 0)



self.frame = QtGui.QFrame(self.centralwidget)

self.layoutBrowser = QtGui.QVBoxLayout(self.frame)

self.layoutBrowser.setSpacing(0)



def buatToolbar(self):

self.layoutToolbar = QtGui.QHBoxLayout()



self.kolomUrl = QtGui.QLineEdit(self.frame)

self.kolomUrl.returnPressed.connect(self.browse)



self.tombolGo = QtGui.QPushButton(text='Go')

self.tombolGo.clicked.connect(self.browse)



self.layoutToolbar.addWidget(self.kolomUrl)

self.layoutToolbar.addWidget(self.tombolGo)



self.layoutToolbar.setContentsMargins(100, 0, 100, 0)

self.layoutBrowser.setContentsMargins(0, 0, 0, 0)

self.layoutBrowser.addLayout(self.layoutToolbar)



def windowBrowser(self):

self.webBrowser = QtWebKit.QWebView()



self.layoutBrowser.addWidget(self.webBrowser)

self.layoutUtama.addWidget(self.frame)

self.setCentralWidget(self.centralwidget)



def browse(self):

url = 'https://google.co.id'

if self.kolomUrl.text():

try:

url = self.kolomUrl.text()



url = url.lower()



print(url)



penampungUrl = []



for i in url:

penampungUrl.append(i)



if penampungUrl[0] != 'h' and penampungUrl[1] != 't' and penampungUrl[2] != 't' and penampungUrl[

3] != 'p' and penampungUrl[3] != 's' and penampungUrl[3] != '/' and penampungUrl[3] != '/':

print('a')

if penampungUrl[0] == 'w' and penampungUrl[1] == 'w' and penampungUrl[2] == 'w' and penampungUrl[

3] == '.':

url = 'https://' + url

else:

urlPengganti = ''

for i in url:

if i != ' ':

urlPengganti += i

else:

urlPengganti += '+'

url = "https://www.google.co.id/search?espv=2&q=" + urlPengganti

except:

urlPengganti = ''

for i in url:

if i != ' ':

urlPengganti += i

else:

urlPengganti += '+'

url = "https://www.google.co.id/search?espv=2&q=" + urlPengganti



self.webBrowser.load(QtCore.QUrl(url))



self.webBrowser.urlChanged.connect(self.setKolomUrl)



self.webBrowser.show()



def setKolomUrl(self):

self.kolomUrl.setText(self.webBrowser.url().toString())



def closeEvent(self, event):

self.destroy()



if __name__ == '__main__':

app = QtGui.QApplication(sys.argv)

main = Browser()

main.setWindowTitle("Mini WebBrowser -> mn-belajarpython.blogspot.co.id")

main.show()

sys.exit(app.exec_())

Dan berikut contoh screenshoot dari mini aplikasi kali ini…

Agar berhasil, Pastikan PC kalian terhubung dengan internet ya temen – temen…

Penjelasan code program Aplikasi Browser PySide versi 2.0

Sekarang saya akan mencoba untuk menjelaskan code program yang sudah saya bagikan di atas tadi.. Agar kalian lebih mudah untuk memahaminya.. Oke, Langsung saja..

[NOTE : Teks berwarna MERAH pada penjelasan adalah Code tambahan yang tidak ada di versi sebelumnyaDan yang Berwarna BIRU akan di hapus di versi berikutnya. Jika Code berwarna MERAH dan komentar berwarna BIRU maka merupakan code baru dan akan di hapus di versi berikutnya]

from PySide import QtCore, QtGui, QtWebKit  //mengimport class yang di butuh kan dari library pyside
import sys  //mengimport sys
class Browser(QtGui.QMainWindow):  //class browser (menurunkan sifat/inheritence class ‘QMainWindow)
    def __init__(self, parent=None, url=”):  /construktor class ‘browser’
        QtGui.QMainWindow.__init__(self)  //menjalankan class parent (QMainWindow)
        self.parent = parent  //menampung nilai variabel parameter ‘parent’
        self.resize(800, 600)  //mengubah ukuran window
        self.centralwidget = QtGui.QWidget(self)  //inisialisasi tempat layout browser
        self.default_url = “https://google.co.id”  //menampung default url
        self.urlTab = url  //menampung default 
        self.layout()  //menjalanka metode ‘layout’
        self.buatToolbar()  //menjalankan metode ‘buatToolbar’
        self.windowBrowser()  //menjalankan metode ‘windowBrowser’
        self.browse()  //menjalankan metode ‘browse’
    def layout(self):  //metode ‘layout’
        self.layoutUtama = QtGui.QHBoxLayout(self.centralwidget)  //membuat layout utama
        self.layoutUtama.setContentsMargins(0, 0, 0, 0)  //agar tidak ada margin. Agar lebih bagus
        self.frame = QtGui.QFrame(self.centralwidget)  //membuat frame
        self.layoutBrowser = QtGui.QVBoxLayout(self.frame)  //membuat layout browser
        self.layoutBrowser.setSpacing(0) //agar tidak ada spasi antara komponen
    def buatToolbar(self):  //metode buatToolbar
        self.layoutToolbar = QtGui.QHBoxLayout()  //membuat layout toolbar
        self.kolomUrl = QtGui.QLineEdit(self.frame)  //membuat kolom url
        self.kolomUrl.returnPressed.connect(self.browse)  .//menjalankan metode ‘browse’ ketika klik enter di kolom url
        self.tombolGo = QtGui.QPushButton(text=’Go’)  //tombol ‘go’
        self.tombolGo.clicked.connect(self.browse)  //menjalankan metode ‘browse’ ketika di klik
        self.layoutToolbar.addWidget(self.kolomUrl)  //memasukkan kolom url ke layout toolbar
        self.layoutToolbar.addWidget(self.tombolGo)  //memasukkan tombol go ke  layout toolbar
        self.layoutToolbar.setContentsMargins(100, 0, 100, 0)  //mengatur margin toolbar
        self.layoutBrowser.setContentsMargins(0, 0, 0, 0)  //mengatur margin layout browser
        self.layoutBrowser.addLayout(self.layoutToolbar)  //memasukkan layout toolbar ke dalam layout Browser
    def windowBrowser(self):  //metode ‘windwoBrowser’
        self.webBrowser = QtWebKit.QWebView()  //membuat webBrowser
        self.layoutBrowser.addWidget(self.webBrowser)  //memasukkan browser ke layout (webBrowser)
        self.layoutUtama.addWidget(self.frame)  //memasukkan frame ke layout utama
        self.setCentralWidget(self.centralwidget)  //memasukkan semua layout ke window
    def browse(self):  //metode ‘browse’
        url = ‘https://google.co.id’  //url default (google)
        if self.kolomUrl.text():  //mengecek apakah kolom url tidak kosong
  //kode di bawah merupakan logika untuk menentukan url yang di masukkan adalah sebuah url atau bukan. Jika bukan, maka di alifkan ke pencarian google
            try:
                url = self.kolomUrl.text()
                url = url.lower()
                print(url)
                penampungUrl = []
                for i in url:
                    penampungUrl.append(i)
                if penampungUrl[0] != ‘h’ and penampungUrl[1] != ‘t’ and penampungUrl[2] != ‘t’ and penampungUrl[
                    3] != ‘p’ and penampungUrl[3] != ‘s’ and penampungUrl[3] != ‘/’ and penampungUrl[3] != ‘/’:
                    print(‘a’)
                    if penampungUrl[0] == ‘w’ and penampungUrl[1] == ‘w’ and penampungUrl[2] == ‘w’ and penampungUrl[
                        3] == ‘.’:
                        url = ‘https://’ + url
                    else:
                        urlPengganti = ”
                        for i in url:
                            if i != ‘ ‘:
                                urlPengganti += i
                            else:
                                urlPengganti += ‘+’
                            url = “https://www.google.co.id/search?espv=2&q=” + urlPengganti
            except:
                urlPengganti = ”
                for i in url:
                    if i != ‘ ‘:
                        urlPengganti += i
                    else:
                        urlPengganti += ‘+’
                    url = “https://www.google.co.id/search?espv=2&q=” + urlPengganti
        self.webBrowser.load(QtCore.QUrl(url))  //memuat url
        self.webBrowser.urlChanged.connect(self.setKolomUrl)  //menjalankan metode ‘setKolomUrl’ jika ada perubahan url
        self.webBrowser.show()  //menampilkan window browser
    def setKolomUrl(self):  //metode ‘setKolomUrl’
        self.kolomUrl.setText(self.webBrowser.url().toString())  //mengubah kolom isi kolom url jika url berubah
    def closeEvent(self, event):  //metode yang akan otomatis dijalankan ketika window di tutup
        self.destroy()  //menghancurkan semua class
if __name__ == ‘__main__’:  //agar di jalankan pertama kali
    app = QtGui.QApplication(sys.argv)  //membuat aplkasi
    main = Browser()  //menjalankan class ‘Browser’
    main.setWindowTitle(“Mini WebBrowser -> mn-belajarpython.blogspot.co.id”)  //mengubah judul window
    main.show()  //menampilkan aplkasi

@font-face{ font-family:”Times New Roman”; } @font-face{ font-family:”宋体”; } @font-face{ font-family:”SimSun”; } @font-face{ font-family:”Calibri”; } @font-face{ font-family:”SimSun”; } p.MsoNormal{ mso-style-name:Normal; mso-style-parent:””; margin:0pt; margin-bottom:.0001pt; mso-pagination:none; text-align:justify; text-justify:inter-ideograph; font-family:Calibri; mso-fareast-font-family:SimSun; mso-bidi-font-family:’Times New Roman’; font-size:10,5000pt; mso-font-kerning:1,0000pt; } span.msoIns{ mso-style-type:export-only; mso-style-name:””; text-decoration:underline; text-underline:single; color:blue; } span.msoDel{ mso-style-type:export-only; mso-style-name:””; text-decoration:line-through; color:red; } @page{mso-page-border-surround-header:no; mso-page-border-surround-footer:no;}@page Section0{ } div.Section0{page:Section0;}

    sys.exit(app.exec_())  //agar tidak langsung close saat di jalankan

Nah itu dia temen – temen penjelasan code programnya.. Mohon maaf apabila ada penjelasan yang kurang jelas, atau bahkan ada kekeliruan… Mohon kasi pembenaran atau pendapat kalian di kolom komentar ya… Biar kita bisa belajar bersama..

Oke terimakasih dan sampai di sini dulu ya… Jangan lupa untuk membaca versi yang lain… Biar ilmunya nambah.. Hehe.. Temikasih sekali lagi dan sekian…

Wassalamualaikum wr. wb.

Source link

Aplikasi Browser Python versi 2

Leave a Reply

Your email address will not be published. Required fields are marked *