2012-02-03 14 views
6

mam tabeli jak następuje:Tabela wzór na arkuszu org

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

ja, do wyszukiwania przez kolumny Xn i S i zwraca wartość Pn dla którego Xn=1 and S=0.

Czy ktoś może doradzić, w jaki sposób mogę to zrobić?

Odpowiedz

2

Użyj babelstwa org: Nazwij tabelę i użyj jej jako danych wejściowych dla funkcji, która wykonuje wyszukiwanie w wybranym języku (z wielu języków obsługiwanych przez system).

w pseudokodzie:

#+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 |