次のエディタでは、PHP の二重引用符で配列要素にアクセスするときのエラーの解決策を紹介します。これは参考になるので、皆さんのお役に立てれば幸いです。エディターをフォローして見てみましょう。
私は現在、グラフィックスとテキストを送信するための WeChat パブリック アカウントを開発しています。配列要素を XML 文字列に結合する必要があります。
foreach ($itemArr as $key => $value){ $items .= "<item> <Title><![CDATA[$value['title']]]></Title> <Description><![CDATA[[$value['description']]]></Description> <PicUrl><![CDATA[$value['picUrl']]]></PicUrl> <Url><![CDATA[$value['url']]]></Url> </item>"; }
結果は次のエラー メッセージでした:
Parse error: syntax error, unexpected '' (T_ENCAPSED_AND_WHITESPACE), expecting identifier (T_STRING) or variable (T_VARIABLE) or number (T_NUM_STRING) in D:\hhp\wamp\www\weixin\wx_sample.php on line 146# #エラーメッセージより シングルクォーテーションの問題のようですが思い切って外したところエラーは出なくなりました。しかし、混乱しているのですが、添え字が文字列である配列要素には引用符を追加する必要はありませんか? PHPの公式マニュアルで配列の説明を確認してみると、次のような記述がありました。通常 配列変数またはスーパーグローバル配列変数が二重引用符で囲まれ、インデックスが文字列である配列要素を参照する場合、インデックス文字列を一重引用符で追加しないでください。では、正しい書き方は何でしょうか?そこで、公式マニュアルを検索し続けたところ、次の記述を見つけました。
$arr = array('fruit' => 'apple', 'veggie' => 'carrot'); // This will not work, and will result in a parse error, such as: // Parse error: parse error, expecting T_STRING' or T_VARIABLE' or T_NUM_STRING' // This of course applies to using superglobals in strings as well print "Hello $arr['fruit']"; print "Hello $_GET['foo']";正しい書き方は 3 つあります。 ##最初の
インデックス文字列の記述方法は、この時点では、インデックスが指定されている配列要素を取得することを意味します。ストリングフルーツと出力リンゴ。
インデックス文字列を記述する 2 番目の方法は、引用符を追加せず、同時に配列変数を中かっこ { } で囲みます。 、fruit 実際には文字列ではなく定数を表すため、fruit 定数値をインデックスとする配列要素を取得することになります。定数 Fruit の値は veggie なので、キャロットが出力されます。3 番目の書き方
# は、一重引用符を追加するだけでなく、配列変数を中括弧 { } で囲んで文字列を引用することです。このように、文字列フルーツをインデックスとする配列要素を取得したい場合は、apple を出力します。後で検索を続けたところ、次のコードが見つかりました:
$arr = array('fruit' => 'apple', 'veggie' => 'carrot'); // This defines a constant to demonstrate what's going on. The value 'veggie' // is assigned to a constant named fruit. define('fruit', 'veggie'); // The following is okay, as it's inside a string. Constants are not looked for// within strings, so no E_NOTICE occurs hereprint "Hello $arr[fruit]"; // Hello apple// With one exception: braces surrounding arrays within strings allows constants// to be interpretedprint "Hello {$arr[fruit]}"; // Hello carrotprint "Hello {$arr['fruit']}"; // Hello apple $arr = array('fruit' => 'apple', 'veggie' => 'carrot'); // This defines a constant to demonstrate what's going on. The value 'veggie' // is assigned to a constant named fruit. define('fruit', 'veggie'); // The following is okay, as it's inside a string. Constants are not looked for // within strings, so no E_NOTICE occurs here print "Hello $arr[fruit]"; // Hello apple // With one exception: braces surrounding arrays within strings allows constants // to be interpreted print "Hello {$arr[fruit]}"; // Hello carrot print "Hello {$arr['fruit']}"; // Hello apple
##// Incorrect. This works but also throws a PHP error of level E_NOTICE because
// of an undefined constant named fruit
//
// Notice: Use of undefined constant fruit - assumed 'fruit' in...
print $arr[fruit]; // apple
<pre name="code" class="php">print $arr['fruit']; // apple
この場合、配列変数がダブルクォーテーションで囲まれていない場合、インデックス文字列にシングルクォーテーションが付加されているか否かに関わらず出力結果は一致しますが、インデックス文字列フルーツと同じ名前の定数が定義されている場合は、一重引用符のないインデックス文字列が表示されますが、出力はニンジンになりますが、一重引用符を追加することは依然として問題ありません。
結論:
1. 配列変数が二重引用符で囲まれていない場合、
(1) 一重引用符で囲まれたインデックス文字列は文字列自体を表します。 ##// This defines a constant to demonstrate what's going on. The value 'veggie'// is assigned to a constant named fruit.define('fruit', 'veggie');// Notice the difference nowprint $arr[fruit]; // carrot
print $arr['fruit']; // apple
#(2) 一重引用符のないインデックス文字列は、文字列そのものを表します。定数。定数が未定義の場合、文字列として解析されます。これは一重引用符を追加するのと同じです。
<pre name="code" class="php">$arr['fruit']
2. 配列変数を二重引用符で囲んだ場合、
( 1) 一重引用符のないインデックス文字列は文字列自体を表します
$arr[fruit]
(2) 中括弧で囲まれた配列変数は文字列と同じ名前の定数を表します
"$arr[fruit]"
#(3) インデックス文字列に一重引用符を追加し、文字列そのものを表す配列変数に中括弧を追加します
"{$arr[fruit]}"(4) インデックス文字列が一重引用符で囲まれており、配列変数が中括弧で囲まれていません。これは間違った書き方です: Parse というエラーが報告されます。エラー: 解析エラー、T_STRING' または T_VARIABLE' または T_NUM_STRING' を予期しています
<pre name="code" class="php"><pre name="code" class="php">"{$arr['fruit']}"
添付ファイル: PHP マニュアル配列の説明 URL
http ://php.net/manual/zh/ language.types.array. php
上記の記事は、PHP の二重引用符で配列要素にアクセスするときのエラーの解決策に基づいています。これがすべての共有内容です。編集者によるこの記事が参考になれば幸いです。また、PHP 中国語 Web サイトをサポートしていただければ幸いです。
#興味があるかもしれない記事:php 1 次元配列の値要素を削除する方法 php ヒント
PHP は画像の逆色処理機能を実現します php スキル ##phppecl メソッドによる拡張機能のインストール例で php スキルを説明します
以上がPHP の二重引用符で配列要素にアクセスするときのエラーの解決策 PHP スキルの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

在PHP中,可以利用implode()函数的第一个参数来设置没有分隔符,该函数的第一个参数用于规定数组元素之间放置的内容,默认是空字符串,也可将第一个参数设置为空,语法为“implode(数组)”或者“implode("",数组)”。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。
