2012-02-03 22 views
6

Ho una tabella come segue:Tabella formula per foglio di calcolo org

| Xn | S | Pn | 
| 0 | 0 | 0 | 
| 1 | 0 | 1 | 
| 0 | 1 | 0 | 
| 1 | 1 | 0 | 

Vorrei per la ricerca in colonne Xn e S e restituire il valore di Pn per il quale Xn=1 and S=0.

Qualcuno può consigliare su come potrei fare questo?

risposta

2

Usa org-babel: assegna un nome alla tabella e utilizzalo come input per una funzione che esegue la ricerca in una lingua di tua scelta (tra le molte lingue supportate da org).

In pseudo-codice:

#+tblname: my_table 
|Xn|S|Pn| 
| 0|0|9 | 
[...] 

#+name filter_table 
#+begin_src lang :var tbl=my_table :results output 
    filter tbl # tbl (my_table by default) is passed in as array of arrays (or list of lists) 
    print matching Pn 
#+end_src 
5
#+tblname: example-table 
| Xn | S | Pn | 
| 0 | 0 | 0 | 
| 1 | 0 | 1 | 
| 0 | 1 | 0 | 
| 1 | 1 | 0 | 

#+source: compute-table 
#+begin_src emacs-lisp :var table=example-table 
(require 'cl) 
(loop for (xn s pn) in (rest table) 
     when (and (= xn 1) (= s 0)) collect pn) 
#+end_src 

#+results: compute-table 
| 1 | 
Problemi correlati