2020년 11월 20일 금요일

[Jython] Jython embed in jar file

1. Jython embed in jar file


package com.zdiv.jython;

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Paths;

import org.python.util.PythonInterpreter;

public class JythonRun {
    public static void main(String[] args) throws IOException {
           PythonInterpreter pi = new PythonInterpreter();
           /*
           pi.set("integer", new PyInteger(42));
           pi.exec("square = integer*integer");
           PyInteger square = (PyInteger)pi.get("square");
           System.out.println("square: " + square.asInt());
           */
           if( args.length == 1 ) {
               pi.exec(script);
               pi.exec(fileToString(args[0]));
           } else {
               System.out.println("Usage: ezJavaFx.jar <file>");
           }
    }
    static String fileToString(String fileName) throws IOException {
        return new String(Files.readAllBytes(Paths.get(fileName)), StandardCharsets.UTF_8);
    }
    static String script = "<jython library script>";
}

2020년 11월 17일 화요일

[Ruby] Read Lines from File

1. Read Lines

Ruby

File.readlines("D:/a.txt").each {
    |i| print i
}

Python 
with open("D:/a.txt","r") as f:
    for l in f.readlines():
        print(l)

Julia
for l in readlines("D:/a.txt")
    print( l, "\n" )
end

[Ruby] Directory List

 

1. Directory List

Ruby

Dir.entries("D:/").each { 
	|i| print File.join("D:/",i), "\n" 
}

Python
import os
for f in os.listdir("D:/"):
    print( os.path.join("D:/",f) )

Julia
for f in readdir("D:/",join=true)
    print( f, "\n" )
end

[Ruby] String Example

1. Time Addition

Ruby

hhmm = [ ]
"12:34 14:56 09:48".split.each { 
	|i| hhmm.append( i.split(":").map{ |i| i.to_i } ) 
}
hhmm = hhmm.transpose.map{ |i| i.reduce{ |a,b| a=a+b } }
print hhmm[0] + hhmm[1]/60, ":", hhmm[1]%60

Python
hhmm = [ 0, 0 ]
for i in "12:34 14:56 09:48".split():
    hm = i.split(":")
    hhmm[0] += int(hm[0]) 
    hhmm[1] += int(hm[1]) 
print (hhmm[0] + hhmm[1]//60, ":", hhmm[1]%60)

Julia
hhmm = [ 0, 0 ]
for i in split("12:34 14:56 09:48") 
    hm = split(i,":")
    hhmm[1] += parse(Int,hm[1]) 
    hhmm[2] += parse(Int,hm[2]) 
end
print( hhmm[1] + hhmm[2] ÷ 60, ":", hhmm[2]%60)


Output
37:18


2020년 11월 15일 일요일

[python] ebook maker

 

ebook maker

import os
import sys
import codecs
import bs4

class html():
    def __init__(self,filename=None):
        self.html = None
        self.bs = None
        if filename:
            self.open(filename)
    def open(self,filename):
        with codecs.open(filename,'r', encoding='utf8') as f:
            self.html = f.read()
        self.bs = bs4.BeautifulSoup(self.html, 'html.parser')  
    def tags(self,tag,attrs=None): #tag='div', attrs = { 'id' : id }
        if attrs == None:
            return self.bs.find_all(tag)
        else:
            return self.bs.find_all(tag,attrs)
    def tag(self,tag): # a.class, a#id, a tag
        return self.bs.select(tag)
    def remove(self,css):
        tags = self.bs.select(css)
        if tags:
            for tag in tags:
                tag.extract()
    def removeTags(self,tag):
        return [s.extract() for s in self.bs(tag)]
    def save(self,filename):
        with codecs.open(filename,'w', encoding='utf8') as f:
            f.write(self.bs.decode_contents())
            f#.write(self.bs.html.decode_contents()) #get_text() or prettify()
    def appendHead(self,tag,text,attrs):
        new_tag = self.bs.new_tag(tag, **attrs) #soup.new_tag('div', **{"data-role": "content"})
        if text: new_tag.string = text
        self.bs.head.append(new_tag)
    def wrapBody(self,tag,attrs):
        wrapper = self.bs.new_tag(tag, **attrs) #soup.new_tag('div', **{"data-role": "content"})
        body_children = list(self.bs.body.children)
        self.bs.body.clear()
        self.bs.body.append(wrapper)
        for child in body_children:
            wrapper.append(child)
            
def files(dirname):
    fs = []
    files = os.listdir(dirname)
    for f in files:
        name,ext = os.path.splitext(f)
        if ext == '.html':
            fs.append(os.path.join(dirname,f))
    return fs
    
def stripTags():
    fs = files(r'D:/Temp2/4')
    for f in fs:
        print(f)
        h = html(f)
        h.remove('iframe')
        h.remove('script')
        h.remove('div.navbar')
        h.remove('div.articleTopAd')
        h.remove('li.previous')
        h.remove('li.next')
        h.remove('div#footerDiv')
        h.remove('nav.col-md-3')
        h.save(f + '.htm')
        
def insertEbookTags(f):
    h = html(f)

    h.appendHead('link', None, { 'href': '../css/bootstrap.min.css', 'rel': 'stylesheet' })
    h.appendHead('link', None, { 'href': '../css/styles.css', 'rel': 'stylesheet' })
    h.appendHead('link', None, { 'href': '../css/highlight.pack.css', 'rel': 'stylesheet' })
    h.appendHead('script', None, { 'src': '../js/highlight.pack.js' })
    h.appendHead('script', r'hljs.configure({tabReplace: '    '}); hljs.initHighlightingOnLoad();', {})
    
    h.wrapBody('div', { 'class': 'main' } )
    h.wrapBody('div', { 'class': 'col-xs-12' } )
    h.wrapBody('div', { 'class': 'row' } )
    h.wrapBody('div', { 'class': 'container-fluid' } )

    h.save(f + '.htm')
            
def makeEbook(directory):
    fs = files(directory)
    for f in fs:
        insertEbookTags(f)
        print(f)

def getLinks(filename):
    h = html(filename)
    data = [ ]
    links = h.tags('a');
    for l in links:
        if not l.attrs:
            continue
        try:
            href = l.attrs['href']
            data.append( '{ "' + l.text.replace('[\r\n]','') + '", "' + href + '" },\n')
        except:
            pass
    with codecs.open(filename + '.txt','w','utf-8') as f:
        for d in data:
            f.write(d)
        
if __name__ == '__main__':
    #stripTags()
    insertEbookTags(r'd:\Android\ebook\work\expect\autoexpect.html')
    #makeEbook('d:\\Android\\ebook\\work\\advbash')
    #getLinks('d:\\Android\\ebook\\work\\advbash\\index.html')
    #getLinks('d:\\Android\\ebook\\bs4_index.html')