15

I googled, installed Devel, Drupal for Firebug, but I can't find it.

I found what I want, I know where it is; I just don't know how to get it.

I'll put this in code brackets, but Devel tells me the file name (which I want to stick into the .tpl.php file) is here:

field_image (Object) stdClass 
  handler (Object) views_handler_field_field 
    view (Object) view 
      result (Array, 2 elements) 
        0 (Object) stdClass 
          _field_data (Array, 1 element) 
            nid (Array, 2 elements) 
              entity (Object) stdClass
                field_image (Array, 1 element) 
                  und (Array, 1 element)
                    0 (Array, 11 elements)                                      
                      filename (String, 23 characters ) FILENAME.jpg

So, how do I get that FILENAME.jpg to be output using PHP?

<?php print $something->other; ?>
Dirk v B
  • 365
  • 4
  • 19
  • 1
    **SimpleXML:** If you have a `print_r` of a SimpleXMLElement object, answers are given here: [How to get values of xml elements?](http://stackoverflow.com/q/2849678/367456) and [Accessing @attribute from SimpleXML](http://stackoverflow.com/q/1652128/367456) – hakre Nov 04 '12 at 09:23
  • Thanks again, hakre. Great answers and comments, and I still reference this post every now and then when I end up diving into code, as I'm mostly occupied with UX & design-related tasks. – Dirk v B Nov 12 '12 at 00:41
  • Explore your print_r output interactively (kudos @mario): http://array.include-once.org/ – hakre Dec 23 '14 at 16:47
  • Start from the top and when ever you are moving to next level from object use arrow ("->") and when you are moving from array place next level element in square brackets. – MilanG Oct 27 '17 at 08:31

9 Answers9

18

Whenever you need to read a value out of a variable, you need to know which expression you need to formulate to access that value.

For a simple variable value this is simple, you just take the variable name and access it as a variable by prefixing it with the $ sign:

var_dump($variable);

This is documented here.

However this does only work for simple datatypes like string or integer. There are as well compound datatypes, namely array and object. They can contain further datatypes, be it simple or compound. You can learn in the PHP manual how to access the values of an array and how you can access them from an object. I think you already know of that a bit, so just for having it linked here.

When you have learned about that, you can then combine this. E.g. if there is an array within an object and therein is a string you would like to get, you need to combine the $ sign and the variable name with the needed accessors, property names and array keys. Then you get your value. The data you have posted shows that you have an object that has some other objects and arrays and in the end you find the variable name.

Some combination example:

var_dump($variable->handler->view[0]->_field_data);

This is based on the data you've provided above. $variable is where you start, -> is used to access object members which need to be named then (like a name for a variable) : handler. As you've seen in your debug output that handler is an object, you need to use again the -> to access the view member of it.

Now view is different because it's an array. You access values of an array by using [] and putting the key in there. The key in my example is a number, 0. And as the value of that array entry is an object again, in the next step you need to use -> again.

You can continue this game until you reach the element that you're interested in. The debug output you already have helps you to write the expression that returns the value. Possibly it is:

$field_image->handler->view->result[0]->_field_data['nid']['entity']->field_image['und'][0]['filename']

But I can not validate that here on my system in full.

However when finding things out, it's helpful to make use of var_dump as you could step by step extend the expression until you find the element. If you make an error you will immediately see. Sometimes it helps to place a die(); after the var_dump statement so not to end the response before it contains to much other data that will hide the information from you. The devel plugin offers additional debug routines to dump values prominent.

hakre
  • 193,403
  • 52
  • 435
  • 836
  • 1
    As the OP has installed Devel, he can use its debugging function, including `dsm()`. – apaderno Jun 12 '11 at 14:15
  • 1
    Arrays and objects do not "contain" datatypes. – Lightness Races in Orbit Jun 12 '11 at 15:30
  • 1
    The difference is that, semantically, a variable most certainly _does_ contain a value, but nothing contains datatypes other than the language and program context. Point taken, though :P – Lightness Races in Orbit Jun 12 '11 at 15:42
  • 1
    Thanks a lot for the elaborate response! All I needed was to "see it done" but I guess if at a later point I screw up, I can go and read this ;) Apologies for the hidden "TLDR" there, it *is* obviously a great answer, but I am one of those people that learns best by seeing something done. The actual answer to my example taught me everything I needed to know for now. Again, great answer, cheers! – Dirk v B Jun 12 '11 at 23:49
6

If this is your object:

field_image (Object) stdClass 
  handler (Object) views_handler_field_field 
    view (Object) view 
      result (Array, 2 elements) 
        0 (Object) stdClass 
          _field_data (Array, 1 element) 
            nid (Array, 2 elements) 
              entity (Object) stdClass
                field_image (Array, 1 element) 
                  und (Array, 1 element)
                    0 (Array, 11 elements)                                      
                      filename (String, 23 characters ) FILENAME.jpg

I'd guess you can find it using:

field_image->handler->view->result[0]->_field_data['nid'][entity]->field_image['und'][0]['filename]

Could be a mistake in there, but the general Idea is: if you have an object, get the variable using ->, and if you have an array, use [key].

Nanne
  • 64,065
  • 16
  • 119
  • 163
4

Let's say you have a node object in $node. You can print it's values very nice with:

dpm($node); // remember this function is declared in devel module

Then you can see the information from $node and expand the internal fields with a click. And with a double click on the field you can see it's php path.

Devel Information of a Drupal node object

You'll get this result:

Devel showing the path after double clicking a field

Hope that helps!

PD: I guess this functionality isn't available on D6's dpm.

Beto Aveiga
  • 3,466
  • 4
  • 27
  • 39
3

Try:

$field_image->handler->view->result[0]->_field_data['nid']['entity']->field_image['und'][0]['filename']
Shef
  • 44,808
  • 15
  • 79
  • 90
0

If you have devel installed and try

krumo ($variable);

Just bear in mind as default only admin users have rights to use the krumo command, but this can be sorted out by looking at the DEVEL role permissions. (don't forget to remove these permissions once your done though)

Matt
  • 412
  • 1
  • 3
  • 14
0
<? print_r($something["other"]); ?>

(where other is this) so result is 'this'

ingrid
  • 555
  • 4
  • 17
0

Let me summarize up

print_r($data); => Traditional view of printing array.

var_dump($data); => Not so much cleaned view , gives you everything but in very suffocated manner

print "<pre>"; print_r($data); => A cleaned view but will not get   data types information.

dpm($data); => It gives you everything, but you need to have installed devel.
nitin.k
  • 91
  • 6
0

You should use field_view_field($entity_type, $entity, $field_name, $display = array(), $langcode = NULL) , that will return renderable array . You can check api document https://api.drupal.org/api/drupal/modules%21field%21field.module/function/field_view_field/7.x

sunil
  • 99
  • 5
0

If you can't use devel module for some reason, another useful "debug" functions could be var_export() and a Drupal wrapper drupal_var_export(). These functions gives the output as PHP code.

Gonzalo
  • 468
  • 1
  • 7
  • 17